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INTRODUZIONE 


Questo è il primo di una serie di volumi sulla sintesi e l'elaborazione digitale del 
suono con Pure Data. L'opera è un adattamento della serie “Musica Elettronica 
e Sound Design - Teoria e Pratica con Max” di A. Cipriani e M. Giri . 

Gli argomenti trattati nel presente volume sono: Introduzione alla Sintesi 
del Suono, Sintesi Additiva, Sintesi Sottrattiva e Filtri, Segnali di Controllo. | 
successivi volumi tratteranno i seguenti argomenti: Campionamento e Audio 
Digitale, Processori di Dinamica, Linee di Ritardo, MIDI e tempo reale, l'Arte 
dell'Organizzazione del Suono, Riverbero e Spazializzazione, Tecniche di Sintesi 
Non Lineare (come AM, FM, waveshaping e tecniche di distorsione del suono), 
Sintesi Granulare, Analisi e Risintesi, Modelli Fisici, Filter Design. 


LIVELLO RICHIESTO 

Tutti i volumi alternano parti teoriche a sezioni di pratica al computer, che vanno 

studiate in stretta connessione. Questo primo volume può essere utilizzato da 

utenti di diverso livello di preparazione. 

Il livello minimo richiesto per chi inizia a studiare il Vol.1 comprende: 

- i primi rudimenti di teoria musicale (note, scale, accordi etc.) 

- una competenza di base nell'utilizzo di un computer (saper salvare un file, 
copiare, cancellare etc.). 

Il testo va studiato alternando ogni capitolo di teoria a quello corrispettivo di 

pratica incluse le attività al computer. La parte teorica non è sostitutiva di testi 

teorici sulla sintesi. Si tratta, invece, di un indispensabile compendio teorico al 

lavoro pratico di programmazione e di invenzione di suoni al computer, ed è 

parte quindi di un sistema didattico organico. Il percorso di questo volume può 

essere svolto in auto-apprendimento oppure sotto la guida di un insegnante. 


I TEMPI DI APPRENDIMENTO 

I tempi di apprendimento, come è ovvio, sono diversi da persona a persona. In 
particolare daremo conto di tempi di mero riferimento nelle due modalità: auto- 
apprendimento e apprendimento sotto la guida di un docente esperto. 


Auto-apprendimento (300 ore globali di studio individuale) 


Capitoli — Argomento Totale ore 
1T+1P+IA Sintesi del suono 100 
2T+2A Sintesi Additiva 60 
3T+3P+IB Sottrattiva e filtri 110 
4T+4P Segnali di Controllo 30 


Apprendimento con docente (corso di 60 ore in classe + 120 di studio individuale) 


Capitoli Argomento Lezioni Feedback Studio Totale ore 
IT+1P+IA Sintesi del suono 16 4 40 60 
2T+2P Sintesi Additiva 10 2 24 36 
3T+3P+IB Sottrattiva e filtri 18 4 44 66 
4T+4P Segnali di controllo 5 1 12 18 
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GLI ESEMPI INTERATTIVI 

II percorso della parte teorica ë accompagnato da molti esempi interattivi repe- 
ribili sul sito. Utilizzando questi esempi, si può fare esperienza immediata del 
suono e della sua creazione ed elaborazione senza aver ancora affrontato alcun 
lavoro pratico di programmazione. In questo modo lo studio della teoria è 
sempre in connessione con la percezione del suono e delle sue possibili modifi- 
cazioni. Far interagire percezione e conoscenza nello studio del sound design e 
della musica elettronica è stato da sempre un nostro obiettivo, e questo criterio 
guida l'intera opera didattica, comprensiva anche di ulteriori materiali online 
che verranno man mano aggiornati ed ampliati. 


TEORIA E PRATICA 

L'impostazione didattica è basata proprio sull'interazione (per noi imprescindibi- 
le) fra teoria e pratica. Uno dei problemi nel campo dell'elaborazione del suono, 
infatti, è quello di avere esperti di teoria che normalmente non si trovano ad 
affrontare problemi concreti riguardanti la pratica dell'invenzione del suono, e 
persone (molto più numerose) che amano lavorare al computer con i suoni, ma 
che spesso hanno una scarsa coscienza tecnico-teorica di cosa stiano facendo, 
e una scarsa capacità di modificare ciò che i software che utilizzano li "costrin- 
gono” a fare. Il mercato propone sempre più oggetti tecnologici meravigliosi, 
ma difficili da personalizzare. Un'informazione spesso approssimativa e poco 
sistematica, unita alla rapida obsolescenza dei sistemi, contribuisce a mantenere 
gli utenti in una (apparentemente piacevole) ignoranza, e quindi in una condi- 
zione di scarsa libertà, costringendoli, in un certo senso, ad usare le macchine e 
il software che acquistano in modo superficiale e ad aggiornarle continuamente 
spesso senza averne compreso la natura profonda. In questo senso intraprendere 
lo studio di questo libro significa anche iniziare ad acquisire una maggiore consa- 
pevolezza dell'uso dei software commerciali di sintesi ed elaborazione del suono. 


L'IMPOSTAZIONE DIDATTICA 

Sulla base dei concetti appena esposti, abbiamo pensato di colmare il vuoto di 
informazione riguardante questa materia, avanzando nella direzione intrapresa 
da Cipriani e Bianchini con il testo “Il Suono Virtuale”, dedicato alla sintesi ed 
elaborazione del suono. La differenza con quel testo è grande, sia per la qualità 
degli esempi proposti, sia perché l'impostazione didattica è completamente 
diversa. Esiste pochissima bibliografia sulla metodologia didattica della musica 
elettronica. A questo scopo abbiamo riflettuto sulla possibilità di approfon- 
dire questa tematica e progettare finalmente un sistema didattico organico, 
mutuando alcune idee e tecniche dalla didattica delle lingue straniere, in modo 
da sviluppare una concezione più aperta e interattiva dell'insegnamento e 
dell'apprendimento. 

Per questo abbiamo inserito, oltre agli esempi interattivi, anche contratti 
formativi per ogni capitolo, attività di ascolto e analisi, test, glossari, indica- 
zioni discografiche e introduzioni storiche (online) oltre a tante altre novità 
contenute nei capitoli di pratica come le attività di sostituzione di parti di 
algoritmi, correzione, completamento e analisi di algoritmi, costruzione di 
nuovi algoritmi, compiti di reverse engineering (cioè, a partire dall'ascolto di 


Estratto da "Pure Data: Musica Elettronica e Sound Design" di F. Bianchi, A. Cipriani e M. Giri 
© 2016 ConTempoNet- Tutti i diritti riservati 


Pure Data: Musica Elettronica e Sound Design - Introduzione IX 


un suono, cercare di inventare un algoritmo che possa creare un suono simi- 
le a quello ascoltato). Nel corso dei capitoli la presenza di tali attività viene 
segnalata con l'icona visibile qui a lato. 

II sistema, composto da piü volumi e una sezione online ë multi-piattaforma, e 
la teoria ë costruita in modo tale da poter fare da base a possibili altri testi di 
pratica basati su software diversi, utilizzando lo stesso percorso didattico. 


PURE DATA 

Questo testo si basa sul volume di A. Cipriani e M. Giri “MUSICA ELETTRONICA 
e SOUND DESIGN - Teoria e Pratica con Max", di cui mantiene intatta la strut- 
tura e la vocazione didattica. La parte dedicata alla pratica, in cui si esemplifi- 
cano le tecniche esposte nei capitoli di teoria, fa riferimento al software Pure 
Data, un programma creato, al pari di Max, da Miller Puckette, e che con Max 
condivide l'impostazione generale e molte altre caratteristiche. 

Pure Data è un linguaggio di programmazione visuale, in cui oggetti grafici 
vengono collegati tra loro. Tali oggetti, che possono eseguire calcoli o ela- 
borare segnale audio, vengono connessi al fine di creare entità anche molto 
complesse come sintetizzatori e processori di segnale, fino ad autentici dispo- 
sitivi sonori automatici. 

Pure Data è un software gratuito e Open Source: può essere liberamente scari- 
cato e utilizzato sui più diffusi sistemi operativi; è anche possibile manipolare il 
codice sorgente al fine di creare versioni personalizzate del programma. Queste 
caratteristiche hanno stimolato la nascita di una nutrita comunità di musicisti, 
programmatori e appassionati, cui hanno fatto seguito alcuni progetti interes- 
santi, fra i quali spicca Pd-extended (che purtroppo non viene più aggiornato e 
che, prima di cessare di esistere, è stata la versione di riferimento della comunità). 
Questo testo fa uso della versione originale di Pure Data (chiamata talvolta 
Pd-vanilla), che continua ad essere aggiornata e mantenuta dallo stesso Miller 
Puckette. Il vantaggio della versione vanilla è quello di garantire la compatibi- 
lità con tutte le piattaforme e soprattutto una maggiore continuità nel tempo 
rispetto alle versioni alternative. 

Il programma, nell'edizione vanilla, contiene una libreria nativa di oggetti non 
molto nutrita, per cui questo testo è corredato da una libreria di abstractions 
(oggetti creati all'interno dell'ambiente, costituiti cioè da oggetti di Pd già 
esistenti) che consente di potenziare le funzionalità del programma e di facili- 
tare la realizzazione di operazioni altrimenti difficoltose a uno stadio iniziale di 
apprendimento. 


INDICAZIONI PRATICHE 

A corredo di questo libro sono stati realizzati molti materiali assolutamente indi- 
spensabili per procedere nell'apprendimento: esempi interattivi, patch (ovvero 
programmi scritti in Max), sound file, estensioni di libreria e altri materiali di 
supporto si trovano tutti nella pagina di supporto online. 


1 (Cipriani e Giri, 2016) 
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Esempi Interattivi 

Durante lo studio della teoria, prima di affrontare la parte pratica, ë importante 
utilizzare gli esempi interattivi. Lavorare con questi esempi sarà di notevole aiuto 
per affrontare poi la parte pratica relativa all'argomento trattato. 


File di esempio 

| file di esempio (patch) sono utilizzabili con il software Pure Data, liberamente 
scaricabile dal sito di Miller Puckette http://msp.ucsd.edu/software.html. Come 
abbiamo detto, il libro si basa sulla versione vanilla (senza estensioni) di Pure Data. 


Alternanza di Teoria e Pratica 

Nel libro i capitoli di teoria si alternano ai capitoli di pratica. Il lettore si troverà 
quindi ad affrontare tutto un capitolo di teoria per poi passare al corrispettivo 
capitolo di pratica (ad esempio tutto il capitolo 1T e poi tutto il capitolo 1P). 
In alternativa può scegliere di leggere un paragrafo di teoria e subito dopo il 
paragrafo corrispondente di pratica per poi passare al paragrafo successivo (ad 
esempio 1.1T e 1.1P, poi 1.2T e 1.2Petc.). 


Gli Interludi 

Da notare che fra il primo e il secondo capitolo, e fra il terzo e il quarto capi- 
tolo ci sono 2 "interludi" tecnici, rispettivamente l'Interludio A e l'Interludio 
B, dedicati specificamente al linguaggio Pure Data e non legati ai temi trattati 
nella teoria, ma ugualmente necessari per procedere nel percorso tracciato nel 
libro. Dopo aver affrontato la teoria e la pratica del primo capitolo, prima di 
passare al secondo capitolo é fondamentale studiare l'interludio A. Ció vale, 
ovviamente anche per l'interludio B, da studiare subito dopo aver completato 
i capitoli 3T e 3P. 


L'apprendimento di Pure Data 

L'apprendimento di Pure Data (e in generale della sintesi ed elaborazione del 
suono) richiede applicazione e concentrazione. Al contrario di molti software 
commerciali, infatti, Pure Data consente una flessibilità massima nella program- 
mazione, e quindi consente una grande libertà a chi programma gli algoritmi; 
ma per poter usufruire di questa libertà ë fondamentale evitare di saltare i pas- 
saggi consigliati nel libro e procedere in modo sistematico. Un apprendimento 
"intuitivo"o a salti dà scarsi risultati in Pure Data, specialmente all'inizio del 
percorso di apprendimento. Questo software ë un vero e proprio "strumento 
musicale" e va studiato come si studierebbe uno strumento tradizionale (ad 
esempio un violino); è necessario cioè utilizzarlo con continuità, partendo dagli 
esercizi di base e affrontando via via le tecniche più complesse per evitare di 
dimenticare le conoscenze e di perdere le abilità acquisite. Solo così sarà possi- 
bile arrivare a una vera padronanza del programma. 


Bibliografia e sitografia 

Si è scelto di inserire nel testo soltanto una bibliografia assolutamente essenzia- 
le, e i riferimenti bibliografici relativi ai testi citati nel libro. Una bibliografia più 
completa e una sitografia è disponibile online. 
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Prima di cominciare 

Per lavorare con questo testo ë necessario accedere agli Esempi Interattivi che si 
trovano alla pagina di supporto online. Durante la lettura dei capitoli di teoria si 
farà costante riferimento agli esempi contenuti nel sito. Per affrontare la parte 
pratica ë invece necessario, come abbiamo detto, aver installato il programma 
Pure Data, reperibile al sito http://msp.ucsd.edu/software.html. Bisogna inoltre 
scaricare la libreria Virtual Sound Macros dalla pagina di supporto di questo 
testo; nella stessa pagina troverete istruzioni dettagliate sulla procedura da 
seguire per la corretta installazione della libreria. Sempre a partire dalla pagina 
di supporto troverete le patch (programmi Pure Data) relative a tutti i capitoli di 
pratica e i file audio per gli esercizi di reverse engineering. 


Commenti e segnalazioni 

Correzioni e commenti sono benvenuti. Vi preghiamo di inviarli per e-mail a: 
Francesco Bianchi frabianchi72@gmail.com 

Alessandro Cipriani a.cipriani@edisonstudio.it 

Maurizio Giri maurizio@giri.it 


https://francescobianchiblog.wordpress.com/ 
http:/Awww.edisonstudio.it/alessandro-cipriani/ 
http://www. .giri.it 
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XII Introduzione 


LEGENDA DEI SIMBOLI UTILIZZATI 


É~ ATTIVITÀ ED ESEMPI INTERATTIVI 
Q - COMPITI UNITARI 
abc e CONCETTI DI BASE 
Ë . DETTAGLI TECNICI 


N + VERIFICA 
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1T 


INTRODUZIONE ALLA SINTESI DEL SUONO 


1.1 SINTESI ED ELABORAZIONE DEL SUONO 

1.2 FREQUENZA AMPIEZZA E FORMA D'ONDA 

1.3 VARIAZIONI DI FREQUENZA E AMPIEZZA NEL TEMPO: INVILUPPI E 
GLISSANDI 

1.4 RAPPORTO TRA FREQUENZA E INTERVALLO MUSICALE 

1.5 CENNI SULLA GESTIONE DEI SUONI CAMPIONATI 

1.6 CENNI SUL PANNING 
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CONTRATTO FORMATIVO 


PREREQUISITI PER IL CAPITOLO 
* CONOSCENZE DI BASE DEGLI STRUMENTI INFORMATICI 
(OPERAZIONI BASE, GESTIONE DELLE CARTELLE, SCHEDA AUDIO ETC.) 
e CONOSCENZA MINIMA DELLA TEORIA MUSICALE (SEMITONI, OTTAVE, TEMPI ETC.) 


OBIETTIVI 

CONOSCENZE 

e CONOSCERE | PERCORSI MEDIANTE | QUALI SI REALIZZA LA SINTESI E L'ELABORAZIONE 
DEL SUONO 

e CONOSCERE | PARAMETRI PRINCIPALI DEL SUONO E LE LORO CARATTERISTICHE 

e CONOSCERE LE CODIFICHE DELL'ALTEZZA E DELL'INTENSITÀ 

e CONOSCERE I RAPPORTI FRA GLI INTERVALLI MUSICALI NEI DIVERSI SISTEMI DI ACCORDATURA 

e CONOSCERE I DIVERSI FORMATI DEI FILE AUDIO 

ABILITÀ 

e SAPER INDIVIDUARE ALL'ASCOLTO MUTAMENTI DI FREQUENZA E D'AMPIEZZA E SAPERNE 
DESCRIVERE LE CARATTERISTICHE 

* SAPER INDIVIDUARE LE VARIE FASI DELL'INVILUPPO DI UN SUONO O DI UN SUONO GLISSATO 


CONTENUTI 

e SINTESI ED ELABORAZIONE DEL SUONO AL COMPUTER 
e TIMBRO, ALTEZZA E INTENSITÀ DI UN SUONO: (TEORIA) 
* GLISSANDO E INVILUPPO D'AMPIEZZA: (TEORIA) 

e RAPPORTI TRA FREQUENZE, ALTEZZE E CODIFICHE MIDI 
e USO DI SUONI CAMPIONATI (CENNI) 


TEMPI - CAP.1 (TEORIA E PRATICA) + INTERLUDIO A 
AUTODIDATTI 
PER 300 ORE GLOBALI DI STUDIO INDIVIDUALE (VOL. |, TEORIA E PRATICA): 
* CA. 100 ORE 
CORSI 
PER UN CORSO GLOBALE DI 60 ORE IN CLASSE + 120 DI STUDIO INDIVIDUALE 
(VOL. |, TEORIA E PRATICA): 
® CA. 16 ORE FRONTALI + 4 DI FEEDBACK 
* CA. 40 DI STUDIO INDIVIDUALE 


ATTIVITÀ 
e ESEMPI INTERATTIVI 


VERIFICHE 
* TEST A RISPOSTE BREVI 
* TEST CON ASCOLTO E ANALISI 


SUSSIDI DIDATTICI 
* CONCETTI DI BASE - GLOSSARIO - UN PO' DI STORIA 
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1.1 SINTESI ED ELABORAZIONE DEL SUONO 


L'introduzione dell'elettronica e, soprattutto, del computer nella musica ha 
consentito a compositori e musicisti di gestire e manipolare i suoni con una 
precisione e una libertà impensabili con i soli mezzi acustici. 

Grazie all'uso del computer ë infatti possibile modellare il suono in ogni modo 
immaginabile; si dice spesso che mentre il compositore “tradizionale” compone 
con i suoni, il compositore elettronico compone i suoni, ovvero entra nel suono, 
nelle sue componenti elementari, creandole e trasformandole a suo piacimento. 
La stessa cosa avviene, per fare un parallelo, nella grafica e nell'animazione: gra- 
zie al computer è possibile creare immagini e sequenze filmate estremamente 
realistiche, che sarebbe difficile produrre con altri mezzi. Attualmente quasi tutti 
gli effetti speciali al cinema sono realizzati con il computer, e sempre più spesso 
i personaggi virtuali “recitano” al fianco di attori in carne ed ossa. 

Il “segreto” di questa flessibilità sta nel passaggio dal mondo analogico (quello 
degli oggetti concreti) a quello digitale (ovvero dei numeri): il processo di digi- 
talizzazione consiste appunto nel trasformare un'informazione (un testo, un 
suono, un'immagine) in numeri.! Una volta che un'immagine o un suono sono 
stati convertiti in una sequenza numerica, possono subire qualunque tipo di 
trasformazione, perché i numeri, grazie a secoli di sviluppo delle tecniche mate- 
matiche, possono essere trasformati e manipolati in qualsiasi modo. 


Questo testo si concentrerà essenzialmente su due aspetti: la sintesi e l'elabo- 
razione del suono. 


- La sintesi del suono (sound synthesis) si riferisce alla generazione elettronica 
di un suono. In pratica si tratta della possibilità di creare un suono sulla base 
di alcuni parametri scelti in funzione del risultato sonoro che si vuole ottenere. 


- L'elaborazione del suono, o del segnale, (signal processing) si riferisce ai 
processi utilizzati per modificare un suono già esistente, ad esempio un suono 
di una chitarra che abbiamo precedentemente registrato, un suono generato 
con una particolare tecnica di sintesi, etc. 


SINTESI DIGITALE DEL SUONO 


Per ottenere qualsiasi tipo di suono utilizzando un linguaggio di programmazio- 
ne per la sintesi e l'elaborazione del suono, scriveremo nel computer le informa- 
zioni sul tipo di "macchina virtuale" che vogliamo costruire (realizzeremo cioe 
un algoritmo?) e le operazioni che questa macchina deve compiere. 


1 Approfondiremo questo concetto nel corso del capitolo. 

2 Un algoritmo é un procedimento che comporta una serie ordinata di istruzioni elementari: queste 
istruzioni, eseguite in successione, permettono di risolvere un problema, di ottenere un risultato. 
Informalmente possiamo dire che anche una ricetta di cucina ë un algoritmo; si tratta infatti di 
una serie di istruzioni che danno come risultato una pietanza. In informatica un algoritmo ë una 
sequenza di istruzioni scritta in un particolare linguaggio di programmazione che permette al 
computer di svolgere un compito definito. 
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Una volta scritte queste istruzioni, chiederemo al programma (Pure Data o altri) 
di eseguirle e di creare un flusso di dati numerici in cui sono rappresentate digi- 
talmente3 tutte le caratteristiche del suono o dei suoni che abbiamo richiesto. 
Tra la generazione di questo flusso di dati digitali e l'ascolto del suono avviene 
un'altra operazione fondamentale che richiede una scheda audio. La scheda 
legge i dati digitali e li trasforma in segnale elettrico che viene inviato all'ampli- 
ficatore e poi agli altoparlanti. In questo caso la scheda opera una conversione 
da digitale ad analogico (D/A), cioè ci consente di ascoltare dei suoni le cui 
caratteristiche sono scritte in un flusso di dati digitali (fig. 1.1). 


scheda in 
audio D/A amplificatore 


ca Í j OS 


fig. 1.1: sintesi in tempo reale 


Questi dati possono anche essere memorizzati in un file audio che verrà salva- 
to nel nostro hard disk, per permettere una riesecuzione dei dati stessi o una 
loro elaborazione. Quando il flusso dei dati è direttamente inviato alla scheda 
audio man mano che viene calcolato si ha una sintesi in tempo reale (real 
time). Quando invece il processo di calcolo viene prima svolto per intero (e 
memorizzato in un file audio) e solo successivamente inviato alla scheda audio 
per l'ascolto si ha una sintesi in tempo differito (non-real time o offline), 
vedi fig. 1.2. 


amplificatore 
scheda 
audio D/A 


file audio H 


programma 


algoritmo I 


HI 


«p» 


fig. 1.2: sintesi in tempo differito e successivo ascolto 


3 Owero sotto forma di numeri. 
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ELABORAZIONE DEL SUONO 


L'elaborazione del suono consiste nella modifica di un suono preesistente, che 
può provenire sia da una fonte live, sia da un file audio. È possibile operare sia in 
tempo reale sia in tempo differito, in diversi modi. Vediamo tre possibilità: 


1) SUONO PREESISTENTE IN TEMPO DIFFERITO, 
ELABORAZIONE IN TEMPO DIFFERITO 


Un suono di flauto, ad esempio, può essere registrato (con un microfono colle- 
gato alla scheda audio che opererà una conversione analogico-digitale4) su un 
file audio. Possiamo creare un algoritmo in cui specificheremo come quel file 
audio deve essere modificato, poi il programma eseguirà quei comandi e creerà 
un nuovo file audio che conterrà un suono di flauto, elaborato dal computer 
secondo le nostre indicazioni. Infine potremo ascoltare questo nuovo sound file 
operando una conversione digitale-analogica (fig. 1.3). 


amplificatore 


scheda : file audio 
0 | ) audio A/D : elaborato i 
=N file audio ! Í file audio : scheda 
: + A audio D/A 
è : file audio 
: 


fig. 1.3: esempio di elaborazione in tempo differito 


2) SUONO PREESISTENTE IN TEMPO DIFFERITO, 
ELABORAZIONE IN TEMPO REALE 


Il suono, come nell'esempio 1, proviene da un file audio. Il programma di elabo- 
razione, eseguiti i comandi, invia il flusso di dati contenenti il suono elaborato 
direttamente alla scheda audio per l'ascolto in tempo reale. Oltre a ciò il pro- 
gramma può registrare, sempre in tempo reale, il risultato dell'elaborazione su 
un file audio (fig. 1.4). 


3) SUONO IN TEMPO REALE, 
ELABORAZIONE IN TEMPO REALE 


II suono proviene da una fonte live. Come nell'esempio precedente, il program- 
ma di elaborazione, eseguiti i comandi, invia il flusso di dati contenenti il suono 
elaborato direttamente alla scheda audio. 


4 Ovvero trasformerà un suono reale in una sequenza di numeri. 
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scheda 
audio A/D 
file audio 
registrato 


fig. 1.4: esempio di elaborazione in tempo reale da suono preesistente 


Naturalmente, anche in questo caso il programma può registrare, sempre in 
tempo reale, il risultato dell'elaborazione su un file audio (vedi fig. 1.5). 


scheda audio 
AID D/A 


programma 


amplificatore 


(file audio 
elaborato) 


L | («pe 


fig. 1.5: esempio di elaborazione in real-time 


Definiamo sistema DSP l'insieme delle risorse hardware e software (scheda 
audio, linguaggio di programmazione etc.) che ci permette di elaborare e/o sin- 
tetizzare digitalmente un suono (o segnale). Il termine DSP é un acronimo che 
sta per Digital Signal Processing (Elaborazione Digitale del Segnale). 


TEMPO REALE - TEMPO DIFFERITO 


Abbiamo visto che sia la sintesi sia l'elaborazione del suono possono avvenire 
in tempo reale o in tempo differito. A prima vista il metodo piü vantaggioso 
appare senz'altro il tempo reale, che ci fornisce un feedback istantaneo e ci con- 
sente di valutare immediatamente l'efficacia dell'algoritmo che si sta mettendo 
a punto e a cui si possono fare le opportune modifiche e migliorie. 

A cosa serve quindi il tempo differito? 

- Innanzitutto a realizzare degli algoritmi che il computer non ë in grado di eseguire 
in tempo reale: se ad esempio per sintetizzare o elaborare un suono che dura 1 
minuto il computer impiega 2 minuti, si dovrà per forza registrare il risultato su disco 
per poterlo ascoltare una volta che il processo di sintesi o elaborazione sia finito. 
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Agli albori della computer music tutti i processi di sintesi ed elaborazione del 
suono erano realizzati in tempo differito, perché un calcolatore non aveva 
abbastanza potenza per il tempo reale. Con l'aumentare della potenza dei 
calcolatori, è diventato possibile realizzare alcuni processi direttamente in 
tempo reale, e nel corso degli anni le capacità di un personal computer di 
realizzare algoritmi di sintesi ed elaborazione in tempo reale sono aumentate 
enormemente. Ma naturalmente, per quanto potenti possano diventare i cal- 
colatori, sarà sempre possibile immaginare un processo talmente complesso 
da richiedere il tempo differito. 

- Esiste poi una seconda categoria di processi che sono concettualmente in 
tempo differito, indipendentemente dalla potenza di calcolo dell'elaboratore: 
poniamo ad esempio di voler realizzare un algoritmo che, data una sequenza 
musicale suonata da uno strumento, scomponga tale sequenza in singole note 
e poi le riordini dalla piü grave alla piü acuta. 

Per realizzare questo algoritmo abbiamo bisogno della sequenza completa, 
molto probabilmente registrata in un file audio, in modo che il computer la 
possa analizzare nel suo complesso e individuare la nota piü grave e via via le 
note successive. 

Questa analisi puó ovviamente avvenire solo in tempo differito, dopo l'esecuzio- 
ne: l'unico computer che potrebbe realizzare questo algoritmo in tempo reale 
(cioé mentre lo strumento sta suonando) é un computer in grado di prevedere 
il futuro! 

- Un altro motivo per cui si ricorre al tempo differito é per risparmiare tempo. 
Contrariamente a quello che si puó pensare, il tempo reale non corrisponde 
alla massima velocità di elaborazione possibile. Immaginiamo ad esempio di 
dover modificare, con una particolare tecnica di elaborazione, un file di suono 
della durata di 10 minuti: se la modifica avviene in tempo reale impiegherà 
ovviamente 10 minuti. Immaginiamo pero che il nostro computer sia abba- 
stanza potente da poter realizzare questa elaborazione, in tempo differito, in 
un minuto. Questo significa che il computer può eseguire i calcoli, per quella 
particolare tecnica di elaborazione, ad una velocità 10 volte superiore al 
tempo reale, ed é quindi conveniente ricorrere al tempo differito. 


1.2 FREQUENZA, AMPIEZZA E FORMA D'ONDA 


Frequenza, ampiezza e forma d'onda sono tre parametri fondamentali del 
suono. Ognuno di questi parametri influenza nell'ascoltatore la percezione 
sonora, in particolare: 


a) la possibilità di distinguere un suono grave da uno acuto (frequenza) 
b) la possibilità di distinguere un suono di forte intensità da uno di intensità 
minore (ampiezza) 

C) la possibilità di distinguere diversi timbri (forma d'onda)? 


? Vedremo piü avanti come il parametro del timbro dipenda in realtà da diversi fattori 
concomitanti. 
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Vediamo una tabella (tratta da Bianchini, R., 2003) delle corrispondenze fra 
caratteristiche fisiche del suono, parametri musicali e sensazione sonora. 


CARATTERISTICA | PARAMETRO MUSICALE | SENSAZIONE 


Frequenza Altezza Acuto € Grave 


Ampiezza Intensità Forte © Piano 


(Chiaro + Scuro 


Forma d'onda Timbro ! : 
Armonico @ Inarmonico etc.) 


TABELLA A : corrispondenza fra caratteristiche del suono, parametri musicali e 
sensazione sonora 


FREQUENZA 


La frequenza è il parametro fisico che determina l'altezza di un suono, cioè la 
caratteristica che consente di distinguere un suono acuto da un suono grave. La 
gamma delle frequenze udibili dall'uomo si estende da circa 20 a circa 20000 
Hertz, cioé da 20 a 20000 cicli al secondo (spiegheremo tra un momento di cosa 
si tratta): al di sotto della minima frequenza percepibile, sotto i 20 cicli al secon- 
do, si hanno gli infrasuoni, al di sopra di quella massima, sopra i 20000 cicli al 
secondo, si hanno gli ultrasuoni.6 Se ci concentriamo sul campo delle frequenze 
udibili, quindi dei suoni, potremo affermare che maggiore ë la frequenza, tanto 
più acuto sarà il suono. 

Ma cosa intendiamo per Hertz o "cicli al secondo"? Per saperlo facciamo riferi- 
mento alla definizione di suono data da Riccardo Bianchini: 


"Per suono si intende quel fenomeno 
meccanico dato da una perturbazione di 
un mezzo di trasmissione (in genere l'aria) 
che abbia caratteristiche tali da essere per- 
cepito dall'orecchio umano." La vibrazione 
viene trasmessa all'aria, per esempio da 
una corda vibrante (vedi fig. 1.6). La corda 
Si sposta avanti e indietro, e durante que- 
fig. 1.6: vibrazione di una corda sto spostamento comprime le particelle 


6 In realtà la massima frequenza udibile diminuisce con l'età. 

7 Ci sono molte teorie sulla natura del suono: Roberto Casati e Jéróme Dokic sostengono che 
l'aria ë un mezzo attraverso cui il suono si trasmette, ma che il suono in sé ë un evento localizzato 
nel corpo risonante, ovvero nel sistema meccanico che produce la vibrazione. (Casati, R., Dokic, 
J. 1994). Un altro punto di vista ë quello espresso da Frova: "con il termine «suono» si dovrebbe 
intendere la sensazione, com'essa si manifesta a livello cerebrale, di una perturbazione di natura 
meccanica, a carattere oscillatorio, che interessa il mezzo interposto tra sorgente e ascoltatore" 
(Frova, A., 1999, pag.4). 
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d'aria (molecole) da un lato e le espande dall'altro. Successivamente il moto si 
inverte, e le molecole che prima erano state compresse si espandono e viceversa. 
Le compressioni e le espansioni (cioë le perturbazioni dell'aria che inizialmente 
era in stato di quiete) si propagano poi con una certa velocità attraverso l'aria 
circostante in tutte le direzioni, dando luogo a onde sferiche. Inizialmente la 
densità delle molecole d'aria ë costante, cioë in ogni unità di volume (per esem- 
pio in un cm3) vi ë lo stesso numero di molecole. 


Questa densità può essere espressa da 
un valore di pressione. Quando l'aria 
viene perturbata, il valore di pressione 
non è più costante, ma varia da punto a 
punto: aumenta dove le molecole sono 
compresse, diminuisce dove le molecole 
sono espanse (vedi fig. 1.7). 


II fenomeno può essere studiato sia dal 
punto di vista dello spazio (osservando 
il valore della pressione nei vari punti in 
un determinato istante) sia dal punto di 
vista del tempo (misurando il valore della 
pressione in uno stesso punto in funzione 
del tempo). Ad esempio, se immaginiamo di trovarci in un determinato punto, 
assisteremo a una successione di compressioni ed espansioni dell'aria (fig. 1.8). 


fig.1.7: compressione e 
rarefazione delle molecole 
dell'aria 


pressione 


fig.1.8: rappresentazione grafica di compressione e rarefazione 


All'istante t 4, ovvero prima dell'istante tọ la pressione dell'aria è al suo valore 
normale, dato che la perturbazione non ë ancora giunta al nostro punto di osser- 
vazione. All'istante to la perturbazione giunge al nostro punto di osservazione, la 
pressione inizia a crescere, giunge al massimo all'istante t4, poi decresce fino a 
tornare al valore normale all'istante t>, continua a decrescere e giunge al minimo 
all'istante t5, per poi risalire fino al valore normale all'istante t4, e cosi via. 
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Si ë fin qui descritto un ciclo del fenomeno. Se questo si ripete sempre allo stesso 
modo il fenomeno si dice periodico.8 Il tempo necessario al completamento di un 
ciclo si dice periodo, si indica con il simbolo T e si misura in secondi (s) o in milli- 
secondi (ms). L'inverso del periodo, cioè il numero di cicli che vengono completati 
in un secondo, si dice frequenza, e si misura in Hertz (Hz) o cicli per secondo (cps). 
Se per esempio un'onda sonora ha periodo T=0.01 s (cioè 1/100 di secondo) la 
sua frequenza sarà di: 1/T = 1/0.01 = 100 Hz (o 100 cicli al secondo)” (ibidem). 


Osservando la figura 1.9 ascoltiamo i suoni dell'esempio interattivo? numero 
1A: possiamo constatare come, all'aumento del numero dei cicli al secondo 
(Hz), corrispondano suoni sempre più acuti. 


amp 


amp 


amp 


amp 


tempo in msec —> 


fig.1.9: quattro suoni di frequenza diversa 


Bv EsemPIO INTERATTIVO 1A * FREQUENZA 


8 Matematicamente una forma d'onda si dice periodica se si ripete regolarmente e per un tempo 
infinito: nella pratica musicale, naturalmente, ci si "accontenta" di durate molto inferiori! In 
genere un'onda ë "musicalmente periodica" quando, ripetendosi con regolarità, persiste per 
un tempo sufficiente a generare la sensazione di altezza corrispondente al periodo dell'onda. 
Approfondiremo la questione nel capitolo 2. 

9 vi ricordiamo che gli esempi interattivi e gli altri materiali di supporto al libro si trovano nella 
pagina di supporto online. 
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Dal momento che si propaga nello spazio, un'onda ha una lunghezza che è 
inversamente proporzionale alla sua frequenza. Chiariamo questo concetto: la 
velocità del suono nell'aria (cioè la velocità con cui si propagano le onde sonore 
a partire dalla sorgente) è di circa 344 metri al secondo.!9 Questo significa che 
un'ipotetica onda di 1 Hz avrebbe una lunghezza di circa 344 metri, perché 
quando ha completato un ciclo ë passato un secondo e in questo tempo si ë 
dispiegata nello spazio per una lunghezza di 344 metri. Un'onda di 10 Hz, inve- 
ce, in un secondo compie 10 cicli, che si dispongono nello spazio di 344 metri 
occupando ciascuno 34.4 metri, cioè un decimo dello spazio totale. 

Per lo stesso ragionamento un'onda di 100 Hz misura 3.44 metri: come si vede 
all'aumentare della frequenza diminuisce la lunghezza, e le due grandezze sono 
quindi, come abbiamo già detto, inversamente proporzionali. 


AMPIEZZA 


II secondo parametro fondamentale del suono ë l'ampiezza, che dà informa- 
zioni sulla variazione della pressione sonora, e che permette di distinguere un 
suono di forte intensità da uno di intensità debole. 

La pressione sonora piü debole che l'orecchio umano ë in grado di percepire si 
dice soglia inferiore di udibilità, mentre la pressione sonora massima che un 
ascoltatore umano puó sopportare si dice soglia del dolore, in quanto al di là 
di questa si ha una vera e propria sensazione di dolore fisico e danni permanenti 
all'organo dell'udito. 

Osservando il fenomeno rappresentato in fig. 1.10, il valore massimo della pres- 
sione si dice ampiezza di picco dell'onda sonora; il valore della pressione in un 
punto qualsiasi si dice invece ampiezza istantanea. 

Quando si indica l'ampiezza di un suono, ci si riferisce al valore dell'ampiezza di 
picco del suono stesso (vedi fig. 1.10). 


pressione 


fig.1.10: ampiezza di un suono 


10 per la precisione questa velocità viene raggiunta quando la temperatura è di 21°. La velocità 
del suono, infatti, ë proporzionale alla temperatura dell'aria. 
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Ad esempio, se indichiamo un'ampiezza di picco 1, avremo un'onda che parte da 
un'ampiezza istantanea 0 (all'istante to); poi l'ampiezza istantanea inizia a cresce- 
re, giunge al massimo all'istante t; (valore 1) poi decresce fino a tornare al valore 
0 all'istante t>, continua a decrescere e giunge al minimo all'istante t3 (-1) per 
poi risalire fino al valore 0 all'istante t4, e cosí via. Questa è la rappresentazione 
dell'ampiezza di un'onda sonora in funzione del tempo. Il processo di digitalizza- 
zione trasforma tale ampiezza in una serie di numeri compresi tra 1 e -1. 

I numeri così ottenuti possono essere usati per rappresentare graficamente la 
forma dell'onda (fig. 1.11). La posizione in cui si trova il ciclo di un'onda in un 
determinato istante viene chiamata fase. 

Approfondiremo il concetto di fase nel par. 2.1. 


valori di pressione 


0 25 50 75 100 
tempo in msec —> 


fig. 1.11: rappresentazione digitale di una forma d'onda. 


Facendo un confronto con l'onda reale (cioè con la successione di compressioni 
ed espansioni delle molecole dell'aria), possiamo vedere che la compressione 
corrisponde ai numeri positivi e l'espansione ai numeri negativi, mentre il valore 0 
indica una pressione non perturbata (l'assenza di segnale corrisponde digitalmen- 
te a una sequenza di zeri). | valori di ampiezza sono convenzionalmente espressi in 
numeri con la virgola e variano tra 0 e 1: se indichiamo 1 (cioè il valore massimo) 
come valore d'ampiezza di picco, avremo oscillazioni fra 1 e -1 (come nell'e- 
sempio citato); se impostiamo 0.5 come valore d'ampiezza di picco (cioè metà 
dell'ampiezza massima), avremo oscillazioni fra 0.5 e -0.5 etc. (vedi fig. 1.12). 


(...) 
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Capitolo 1T - Introduzione alla sintesi del suono 


II capitolo prosegue con: 


Forma d'onda 

La sinusoide 

Altre forme d'onda 

Onde bipolari e unipolari 

Uso dei logaritmi nel calcolo dei decibel 


1.3 VARIAZIONI DI FREQUENZA E AMPIEZZA NEL TEMPO: 
INVILUPPI E GLISSANDI 
Inviluppi di strumenti acustici 
Inviluppi di suoni sintetici 
Glissandi 
Curve esponenziali e logaritmiche 


1.4 RAPPORTO TRA FREQUENZA E INTERVALLO MUSICALE 


1.5 CENNI SULLA GESTIONE DEI SUONI CAMPIONATI 
La digitalizzazione del suono 


1.6 CENNI SUL PANNING 


ATTIVITÀ 
e Esempi interattivi 


VERIFICHE 
e Test a risposte brevi 
e Test con ascolto e analisi 


SUSSIDI DIDATTICI 
e Concetti di base - Glossario - Un po' di storia 
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1P 


SINTESI DEL SUONO CON PURE DATA 


1.1 INSTALLAZIONE E PRIMI PASSI CON PD 

1.2 FREQUENZA, AMPIEZZA E FORMA D'ONDA 

1.3 VARIAZIONI DI FREQUENZA E AMPIEZZA NEL TEMPO: 
INVILUPPI E GLISSANDI 

1.4 RAPPORTO TRA FREQUENZA E INTERVALLO MUSICALE 
E TRA AMPIEZZA E LIVELLO DI PRESSIONE SONORA 

1.5 CENNI SULLA GESTIONE DEI FILE CAMPIONATI 

1.6 CENNI SUL PANNING 

1.7 ALTRE CARATTERISTICHE DI PD 
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CONTRATTO FORMATIVO 


PREREQUISITI PER IL CAPITOLO 

* CONOSCENZE DI BASE DEGLI STRUMENTI INFORMATICI 
(OPERAZIONI BASE, GESTIONE DELLE CARTELLE, SCHEDA AUDIO, ETC.) 

* CONOSCENZA MINIMA DELLA TEORIA MUSICALE (TONI, SEMITONI, OTTAVE, TEMPI ETC.) 

e CONTENUTI DEL CAP. 1 DELLA PARTE DI TEORIA (SI CONSIGLIA DI STUDIARE UN CAPITOLO PER 
VOLTA, AFFRONTANDO PRIMA LA TEORIA E POI LA PRATICA CON PD) 


OBIETTIVI 

ABILITÀ 

e SAPER UTILIZZARE TUTTE LE FUNZIONI DI BASE DEL SOFTWARE PD 

e SAPER SINTETIZZARE SUONI IN SEQUENZA E IN SOVRAPPOSIZIONE UTILIZZANDO OSCILLATORI SINU- 
SOIDALI, AD ONDA QUADRA, TRIANGOLARE O DENTE DI SEGA 

* SAPER CONTROLLARE IN MODO CONTINUO L'AMPIEZZA, LA FREQUENZA E LA SPAZIALIZZAZIONE 
STEREOFONICA DI UN SUONO (USO DI SPEZZATE DI RETTA E DI ESPONENZIALE PER GLISSANDI, 
INVILUPPI D'AMPIEZZA E MOVIMENTO DEL SUONO NELLO SPAZIO STEREO) 

* SAPER GENERARE SEQUENZE CASUALI DI SUONI SINTETIZZATI 

* SAPER GESTIRE L'UTILIZZO ELEMENTARE DEI SUONI CAMPIONATI 

COMPETENZE 

* SAPER REALIZZARE UN PRIMO STUDIO SONORO DI DUE MINUTI BASATO SULLE TECNICHE ACQUI- 
SITE E MEMORIZZARLO SU FILE AUDIO 


CONTENUTI 
e SINTESI ED ELABORAZIONE DEL SUONO AL COMPUTER 
* TIMBRO, ALTEZZA E INTENSITÀ DI UN SUONO 

* GLISSANDO E INVILUPPO D'AMPIEZZA 

e RAPPORTI TRA FREQUENZE, ALTEZZE E CODIFICHE MIDI 
e USO DI SUONI CAMPIONATI (CENNI) 


TEMPI - Cap. 1 (TEORIA E PRATICA) + INTERLUDIO A 
AUTODIDATTI 
PER 300 ORE GLOBALI DI STUDIO INDIVIDUALE (VOL. |, TEORIA E PRATICA): CA. 100 ORE 
CORSI 
PER UN CORSO GLOBALE DI 60 ORE IN CLASSE + 120 DI STUDIO INDIVIDUALE (VOL. |, TEORIA 
E PRATICA): CA. 16 ORE FRONTALI + 4 DI FEEDBACK - CA. 40 DI STUDIO INDIVIDUALE 


ATTIVITÀ 
® SOSTITUZIONE DI PARTI DI ALGORITMI, CORREZIONE, COMPLETAMENTO E ANALISI DI ALGORITMI, 
COSTRUZIONE DI NUOVI ALGORITMI 


VERIFICHE 
* COMPITI UNITARI DI REVERSE ENGINEERING 


SUSSIDI DIDATTICI 
* LISTA COMANDI PRINCIPALI - LISTA OGGETTI NATIVI DI PD - LISTA OGGETTI DELLA LIBRERIA 
VIRTUAL SOUND - LISTA MESSAGGI PER OGGETTI SPECIFICI - GLOSSARIO 
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1.1 INSTALLAZIONE E PRIMI PASSI CON PD 


Installazione e configurazione del sistema 


Prima di procedere alla lettura di questo capitolo ë necessario svolgere le 
seguenti operazioni: 


1. scaricare e installare il software Pure Data (Pd); 

2. scaricare e installare la libreria Virtual Sound; 

3. scaricare il materiale di supporto a corredo di questo testo; 
4. configurare il proprio sistema audio e MIDI. 


Il software Pure Data! può essere scaricato dal sito http://msp.ucsd.edu/softwa- 
re.html, dove si trovano i file per i sistemi operativi Windows e Mac OSX (anche 
a 64 bit). Per installare il software basta eseguire il file scaricato e seguire le 
istruzioni che compaiono. Su sistemi Linux le cose sono leggermente più com- 
plicate, ma solitamente Pd può essere installato tramite l'applicazione synaptic 
senza particolari problemi. Per una trattazione più approfondita in merito all'in- 
stallazione sui diversi sistemi operativi vi invitiamo a leggere il documento relati- 
vo (MESD_installazione_Pd.pdf) che trovate nella pagina di supporto online. 


Questo testo fa riferimento a Pd-0.47-1 (l'ultima versione stabile in circolazione 
al momento della pubblicazione di questo libro), ma gli esempi dovrebbero fun- 
zionare anche con le precedenti versioni, fino alla 0.45 inclusa. Nel caso di alcu- 
ne installazioni in sistemi Linux, potrebbero non essere disponibili le versioni più 
recenti del software, quindi bisogna “adeguare” le patch affinché funzionino 
su versioni più vecchie dell'applicazione. Un pdf allegato (MESD Pd old ver- 
sions.pdf), nel sito sopra citato, spiega come fare. 


Sullo stesso sito dovete scaricare la libreria Virtual Sound, che é assolutamente 
necessaria per garantire il funzionamento degli esempi del testo. Per installarla 
correttamente osservate la seguente procedura: 


1. Scaricate il file VirtualSoundLibraryPd.zip sul vostro computer e scom- 
pattatelo: avrete cosi la cartella Virtua! Sound Library Pd; 

2. Aprite Pd e dal menu Pd/Preferences (Mac) o File/Preferences (Altri siste- 
mi) aprite la sezione Path. Fate clic su New: si aprirà una finestra in cui 
dovete cercare e selezionare la cartella Virtua! Sound Library Pd. Una 
volta trovata e selezionata fate clic su Ok; 

3. Riavviate Pd. 


1 Cercando su Internet potreste imbattervi in versioni diverse di Pure Data. In particolare è molto 
diffusa la versione Pd-extended, un'edizione molto ricca di librerie esterne che purtroppo non è più 
mantenuta e per tale ragione si basa su una versione di Pure Data superata. Questo testo è basato 
su Pure Data, edizione vanilla, che rappresenta la versione originale del programma ed è mantenuta 
dal suo creatore Miller Puckette. Gli esempi del libro NON funzionano tutti su Pd-extended. 
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Se la procedura ë andata a buon fine Pd cercherà gli oggetti della libreria Virtual 
Sound in automatico, ogni volta che un oggetto viene richiamato dall'utente2. 
Per maggiori informazioni consultate i documenti relativi presenti nel sito. 


Il materiale di supporto è raccolto nel file MESD PD MATERIALE vol 1.zip, 
che potete scaricare e scompattare in una posizione arbitraria del vostro compu- 
ter. Da li potete aprire i file a corredo dei capitoli, inclusi quelli che riguardano 
le attività e i compiti di reverse engeneering. 


Configurazione dell'audio 


Per verificare che l'audio funzioni osservate la seguente procedura: 


1. Dal menu Media/Audio Settings accertatevi che i campi /nput Device 
1 e Output Device 1 contengano il nome della vostra scheda audio, se 
così non fosse, scegliete la vostra scheda dal menu a tendina relativo (in 
entrambi i campi); 

2. Dal menu Media/Test Audio and MIDI aprite la finestra relativa e, nella 
sezione a sinistra, etichettata con ‘TEST TONES', mettete la spunta su '80' 
e su ‘noise’ (fig. 1.1). Accertatevi che il computer non sia in mute! 


Welcome to Pd ("Pure Data"). You can use this window to test 
audio and MIDI connections. To see Pd's DOCUMENTATION, 
select "getting started" in the Help menu. 


TEST TONES AUDIO INPUT (RMS dB) 


Le "hog [o fo ) [o o | [o Yo ) o Yo ) [X] input-hipass 


tone 
5 6 A T" 


OFF [69  Jeitch ari * "© nt 
[je [dae DADI DIDI RI MUS — 2. 


eio: 
AUDIO OUTPUT ON/OFF 
(100 max) IL 1 H 1-8 
" i ç 3-10 
MIDI IN input-monitor-gain b) 5-12 
7-14 
MIDI OUT Tola 
= 17-24 
25-32 


Pd is Free software under the BSD license. See LICENSE.txt 
in the distribution for details. 


fig. 1.1: la finestra per verificare il funzionamento dell'audio all'interno di Pd. 
Per eventuali problemi consultate il documento MESD_audio_config.pdf che 
si trova nella pagina di supporto online. 


Per la configurazione del protocollo MIDI, rimandiamo il lettore al capitolo IB.1 
(“Cenni sul MIDI") o, eventualmente, al pdf allegato (MESD MIDI config.pdf). 


Ora possiamo cominciare davvero! 


2 Tutti i nomi degli oggetti della libreria Virtual Sound iniziano con il prefisso vs. seguito dal nome 
dell'oggetto. 
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Primi passi con Pd 


Lanciamo il programma Pd e selezioniamo dal menü File la voce New (oppure 
digitiamo <Mac: Command-n> <Win e Linux: Control-n>)3: apparirà una fine- 
stra, la Patcher Window, detta Canvas (tela), nella quale possiamo cominciare 
ad assemblare il nostro primo algoritmo. Un algoritmo si configura come un 
insieme di “scatole”, dette genericamente text box, che contengono stringhe 
di testo e numeri. Un insieme di text box collegati fra loro si chiama patch, in 
analogia con i vecchi moduli dei sintetizzatori analogici che venivano program- 
mati con connessioni fisiche effettuate tramite cavi chiamati patch cords). 


Dopo aver aperto una patcher window premete la combinazione di tasti <C-1>, 
o in alternativa aprite il menu Put e selezionate la voce Object: comparirà un 
rettangolo con i lati tratteggiati nel quale é possibile scrivere delle sequenze di 
caratteri (fig. 1.2) grazie alla presenza del cursore lampeggiante. 


Questo rettangolo è detto object box. 
Scrivete all'interno la stringa di caratteri 'osc- 
440'4 e fate clic col mouse all'esterno del 
rettangolo (fig. 1.3). In questo modo avete 
fig. 1.2: object box generico creato l'oggetto [osc- ], cioè l'oscillatore 

sinusoidale. In Pd una sequenza di caratteri 
priva di spazi è detta atomo (atom) e può essere costituita da un numero, da 
una stringa letterale o un qualunque simbolo. Un oggetto in Pd è costituito da 
un atomo iniziale che definisce il nome dell'oggetto e da uno o più atomi che 
costituiscono gli eventuali argomenti di inizializzazione (creation arguments). 
Con l'operazione appena compiuta abbiamo creato un'oggetto della classe 
[osc- ] con un creation argument pari a 440. 


pog 
I 
I 


I rettangolini nella parte alta e bassa dell'og- 


getto sono rispettivamente gli ingressi (inlet) 
e l'uscita (outlet), e vedremo tra poco come si 
fig. 1.3: l'oggetto [osc-] utilizzano. (NB: Se l'oggetto non dovesse avere 


questo aspetto vuol dire che c'è un problema, 
leggetevi le FAQ alla fine di questo paragrafo). 


nu 


3 su Mac OS X teniamo premuto il tasto Command e digitiamo "n"; su Windows e Linux teniamo 
premuto il tasto Control e digitiamo "n". Da ora in poi i comandi Command e Control saranno 
abbreviati in "C". Ad esempio per indicare l'apertura di una nuova Canvas il comando sarà «C-n». 
4 Il simbolo “~” (tilde), che segue la stringa “osc”, si ottiene usando diverse combinazioni di tasti. 
Su MAC OS X: <ALT-5>; su Linux: <ALT GR-ì>; su Windows: <ALT-126>; la sequenza “126” va 
digitata sul tastierino numerico mentre ALT resta premuto. In mancanza del tastierino, come nei 
portatili, usare la combinazione <ALT-Fn-126>. 
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fig. 1.4: l'oggetto [vs.gain-] 


Ora creiamo un altro oggetto, [vs. 
gain-], che fa parte della libreria Virtual 
Sound e che ha l'aspetto del fader di un 
mixer (vedi fig. 1.4). Come per [osc- ], 
premete <C-1> per creare un object box 
generico e al suo interno scrivete la strin- 
ga ‘vs.gain-’, dopo di che fate clic su 
un punto vuoto della Patcher Window®. 
Questo oggetto grafico fa parte della cate- 


goria GUI (graphical user interface) e permette l'interazione diretta tramite il 
mouse. Spostate questo oggetto sotto [osc- ], e collegate l'uscita di [osc-] 
con l'ingresso di [vs.gain-]. Per creare un collegamento è necessario usare 


dei cavi, detti patch cords. 


fig. 1.5: collegare gli oggetti 


fig. 1.6: l'oggetto [dac-] 


ini | 
N 


fig. 1.7: la nostra prima patch 


Per questa operazione si usa il mouse 
seguendo la sequenza di azioni premi-tra- 
scina-rilascia (click, drag and drop); portate 
il puntatore (che ha la forma di una piccola 
mano) sull'outlet di [osc-]; appena il 
puntatore diventa un circoletto, fate clic 
col mouse, trascinate il puntatore sopra 
l'inlet di [vs.gain-] e appena diventa 
nuovamente un circoletto rilasciate il pul- 
sante del mouse. Se non sono stati fatti 
errori il risultato dovrebbe essere simile a 
quello della figura 1.5. 


Abbiamo collegato l'oscillatore all'ogget- 
to [vs.gain-] che serve a regolarne 
il volume. Adesso dobbiamo inviare il 
segnale audio all'uscita: creiamo l'oggetto 
[dac-] (fig. 1.6) e spostiamolo sotto 
a [vs.gain-]. Colleghiamo l'uscita di 
[vs.gain-] prima all'inlet sinistro di 
[dac-], poi, ripetendo le operazioni di 
trascinamento dei patch cords, all'inlet 
destro (fig.1.7). 


> Se l'oggetto non appare, forse non avete scritto correttamente il nome, oppure non avete 
installato la libreria Virtua! Sound: in quest'ultimo caso tornate all'inizio del capitolo e seguite le 


istruzioni per l'installazione. 
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Attenzione: verificate di aver usato l'uscita sinistra di [vs .gain-] per entram- 
bi i collegamenti. Se vi accorgete che uno dei due cavi esce dell'outlet destro di 
[vs.gain-] potete cancellarlo in questo modo: selezionatelo con un clic (il 
cavo diventerà blu) e premete il tasto di cancellazione (quello che usate quando 
dovete cancellare del testo); a questo punto ricollegate gli oggetti nel modo 
corretto. 


Probabilmente ora vorrete salvare la patch su disco; fatelo pure, ma con un'av- 
vertenza: NON date alla patch lo stesso nome di un oggetto Pd! Ad esempio, 
non chiamate questa patch "osc-": è il modo migliore per confondere Pd 
e avere risultati inaspettati la prossima volta che ricaricherete la patch. Dal 
momento che è impossibile ricordare tutti i nomi degli oggetti di Pd (per evitare 
di usarli come nome di patch), un buon modo per scongiurare il “pericolo” è 
dare al file un nome composto da più parole, ad esempio “test oscillatore”, 
oppure "test oggetto osc-", o quello che preferite: nessun oggetto di Pd ha 
un nome composto da piü parole. Non trascurate questo consiglio, molti dei 
malfunzionamenti riscontrati dagli utenti di Pd alle prime armi derivano proprio 
dal fatto che prima o poi creano un file con lo stesso nome di un oggetto. 


Bene, abbiamo realizzato la nostra prima patch e siamo pronti per farla funzio- 
nare. Manca peró ancora un passaggio: finora abbiamo lavorato in Edit Mode, 
cioé la modalità che ci permette di assemblare la patch spostando e collegan- 
do gli oggetti; ora, per far suonare la nostra patch dobbiamo passare in Run 
Mode, premendo la combinazione «C-e», oppure dal menu Edit togliendo la 
spunta alla voce Edit Mode. 

Adesso con la combinazione «C-/» (oppure dal menu Media/DSP On) attiviamo 
il motore audio? e alziamo la levetta presente nell'oggetto [vs.gain-]/: 
dovremmo udire un suono, per la precisione un La sopra il Do centrale. Con 
la combinazione <C-.> (menu Media/DSP Off) possiamo invece “spegnere” la 
patch. Se non avete sentito alcun suono consultate le FAQ alla fine di questo 
paragrafo. 


Analizziamo ora il nostro algoritmo: l'oggetto [osc- ] è un oscillatore, ovvero 
un generatore di suono che nel nostro caso genera un'onda sinusoidale, e il 
numero 440 indica la sua frequenza; questa sinusoide, cioè, si ripete 440 volte 
al secondo8. In altre parole [osc- ] ë il nome dell'oggetto e 440 è il suo argo- 
mento, vale a dire il valore che l'oggetto in questione utilizza per operare, in 
questo caso appunto 440 Hz. 


6 In Pd il motore audio non ë attivo per impostazione predefinita. Bisogna attivarlo (e disattivarlo) 
all'occorrenza. Questo perché Pd ë un vero e proprio linguaggio di programmazione che, oltre alla 
sintesi del suono, può svolgere molte operazioni che non richiedono l'uso dell'audio. 

7 Quando si crea un oggetto [vs.gain-], per impostazione predefinita questo avrà la levetta 
abbassata al minimo. 

8 Tutti questi concetti vengono spiegati nel paragrafo 1.2 della parte di teoria. 
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Questo oggetto è collegato con l'oggetto [vs.gain-] e quindi il segnale 
che genera viene passato a quest'ultimo, che come abbiamo visto modifica il 
volume del segnale. Il segnale modificato passa poi a [dac-], la cui funzione 
è quella di mandare il segnale alla scheda audio del computer. Quest'ultima 
effettua la conversione digitale-analogica del segnale, cioè trasforma i numeri 
in segnale audio che possiamo udire attraverso le casse collegate al computer. 
Il nome “dac” peraltro è un acronimo che sta per Digital to Analog Converter 
(Convertitore Digitale-Analogico). 


Cerchiamo di approfondire ulteriormente questa patch; oltre a udire il suono, 
infatti, possiamo “vederlo”. Salvate la patch che avete appena realizzato in una 
cartella apposita che potreste chiamare, ad esempio, “le mie patch” (ci servirà 
nel prossimo paragrafo) e chiudete la Patcher Window. 


Ora scaricate e scompattate (se non l'avete ancora fatto) il file MESD_PD_ 
MATERIALE_vol_1.zip che si trova nella pagina di supporto online. Poi aprite 
il file 01_01.pd (fig. 1.8) che trovate nella cartella “MESD_PD_MATERIALE/ 
VOL 1/01 patch". 


$0-scope 


|»-0.95294 


fig. 1.8: file 01 01.pd 


Qui abbiamo aggiunto alla patch alcuni nuovi oggetti. Gli oggetti sulla sinistra 
in cui sono visibili dei valori numerici si chiamano [vs.number-] e mostrano, 
sotto forma di numero, il contenuto del segnale che ricevono; gli oggetti qua- 
drati sulla destra si chiamano [vs.scope-] e sono degli oscilloscopi che ci 
fanno vedere il segnale come un'onda che si muove su uno schermo; l'oggetto 
[vs.dbtoa] e l'oggetto collegato (che si chiama number box?) ci fanno vede- 
re di quanto [vs. gain-] amplifica o attenua il segnale che riceve. 


9 Il number box si crea con la combinazione <C-3> o dal menu Put/Number. 
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Avviamo l'audio con la combinazione <C-/> e osserviamo i numeri mostrati dal 
[vs.number-] in alto a sinistra: questi numeri sono prodotti dall'oggetto 
[osc-] e, se li osserviamo per un po', ci renderemo conto che sono valori 
positivi e negativi compresi fra 1 e -1. Sul lato destro vediamo il [vs.scope-] 
superiore che ci mostra questi stessi numeri sotto forma di grafico: nella metà 
superiore del riquadro vengono rappresentati i valori positivi, in quella inferiore i 
negativi. Nel riquadro del [vs.scope-] viene mostrato non un singolo nume- 
ro, ma una sequenza di diverse centinaia di elementi, che vengono visualizzati 
come punti nel riquadro stesso: questi punti sono molto vicini tra loro e nell'in- 
sieme ci appaiono come una linea curva. Questi elementi, questi numeri, nella 
terminologia della musica digitale si chiamano campioni. La linea che oscilla 
sinuosamente in alto e in basso all'interno dell'oscilloscopio è appunto la forma 
d'onda sinusoidale prodotta da [osc- ]. 


Se abbassate fino al valore più basso il livello di [vs.gain-] vi accorgerete che 
il [vs.number-] e il [vs.scope-] in basso mostreranno rispettivamente il 
numero 0 e una linea piatta. Se alziamo nuovamente il cursore di [vs.gain-] 
vediamo che il [vs.number-] ci mostra dei numeri dapprima molto piccoli 
e poi via via sempre più grandi man mano che aumentiamo il volume. Nello 
stesso tempo la linea piatta del [vs.scope-] in basso comincia a diventare 
ondulata e ad assomigliare a quella del [vs.scope-] in alto: quella che viene 
modificata è l'ampiezza del segnale; più alziamo il cursore e più l'oscillazione 
diventa ampia. 

Se però alziamo troppo il cursore di [vs.gain-] vediamo che i numeri comin- 
ciano a superare i limiti di 1 e -1 e che la forma d'onda rappresentata nell'o- 
scilloscopio è diventata troppo ampia e appare tagliata. Inoltre potete osservare 
che il suono cambia, diventa distorto. 


Da tutto ciò possiamo trarre alcune conclusioni: 


1. l'oggetto [osc-] produce una sequenza di valori digitali che seguono 
l'andamento di una funzione seno!0; 

2. i limiti numerici di questa sinusoide sono 1 e -1. Come si vede nell'imma- 
gine che appare nel [vs.scope- ] superiore, questi sono anche i limiti 
massimi, superati i quali il suono viene distorto; 

3. l'oggetto [vs.gain-] modifica l'ampiezza della sinusoide, e fa sì che 
i campioni in entrata siano diversi dai campioni in uscita. Come fa? 
Moltiplicando i valori che riceve per una certa quantità che dipende dalla 
posizione del cursore. Quando il cursore ë nella posizione piü bassa il 
segnale viene moltiplicato per 0, e il risultato ë una sequenza di zeri, 
come abbiamo visto, perché qualsiasi numero moltiplicato per 0 dà come 
risultato 0. Man mano che alziamo il cursore il fattore di moltiplicazione 
aumenta. 


10 per la verità, come vedremo successivamente, [osc-] segue l'andamento di una funzione 
coseno. 
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Se ad esempio lo portiamo a -6, il fattore di moltiplicazione corrispondente sarà 
circa 0.5 (come si vede dal number box collegato all'uscita di [vs.gain-]), 
che significa dimezzare l'ampiezza, perché moltiplicare un numero per 0.5 
equivale a dividerlo per 2. Se poi lo alziamo fino a 011 (spostando il cursore 
finché l'indicatore in basso non indichi questo valore) i campioni in entrata non 
subiscono variazioni in uscita, ma rimangono identici perché moltiplicati per 1 
(osservate ancora il number box collegato a [vs.dbtoa]). 


Infine alziamo ulteriormente il cursore (il massimo consentito dall'oggetto è un 
valore di +6): ora i valori estremi dei campioni superano il limite di 1 e -1, ma 
questi campioni vengono riportati entro i limiti durante la conversione digitale- 
analogica: questo fa sì che la forma d'onda non sia più una sinusoide, poiché 
l'onda appare tagliata (come vediamo nell'oscilloscopio inferiore). In realtà i 
campioni fuori range vengono semplicemente riportati alla massima ampiezza 
disponibile, e il suono distorto che sentiamo è relativo a questa nuova forma 
d'onda. 


Abbiamo trattato più a fondo i concetti di ampiezza, frequenza e forma d'onda 
nel par. 1.2 della teoria, riassumiamo alcuni concetti basilari: 


e l'ampiezza è il parametro fisico da cui dipende l'intensità del suono, cioè 
il parametro che ci fa percepire forte o piano un determinato evento 
sonoro; i valori assoluti d'ampiezza (cioè indipendenti dal segno) in Pd 
vanno da un minimo di 0 a un massimo di 1; 

e la frequenza è il parametro fisico da cui dipende l'altezza del suono, cioè 
il parametro che ci fa percepire un suono come grave o acuto. | valori 
sono espressi in Hertz (Hz), e quindi dovremo tener conto che i suoni 
udibili dall'uomo sono fra circa 20 e circa 20000 Hz; 

e la forma d'onda, che nel caso di [osc-] come abbiamo visto è una 
sinusoide, è un parametro fondamentale che concorre a definire il timbro 
del suono, cioè quella qualità del suono che ci consente di percepire la 
differenza, ad esempio, fra il Do di una chitarra e quello di un sassofono. 


FAQ (Frequently Asked Questions) 


FAQ significa “Domande Frequenti” e in questa sezione cercheremo di dare una 
risposta ad alcuni dei problemi più comuni che si incontrano quando si comincia 
a lavorare con Pd. Leggetele attentamente anche se non avete incontrato alcun 
problema: contengono informazioni che vi saranno utili nel seguito della lettura 
di questo libro. 


1) Domanda: Ho creato un oggetto chiamato "osc-440" come c'è scritto in 
questo capitolo, ma l'oggetto non ha né ingressi né uscite. Perché? 


11 Per ragioni che vi saranno chiare in seguito, [vs.gain-] usa la scala dei deciBel (vedi cap. 1.2 
della parte teorica), quindi il valore 0 corrisponde all'ampiezza 1, che è quella massima possibile. 
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Risposta: Controllate di aver messo uno spazio tra "osc-" e "440" perché il 
primo ë il nome dell'oggetto e il secondo ë l'argomento, che in questo caso 
rappresenta la frequenza del suono. Se le due parole sono attaccate Pd cercherà 
un oggetto inesistente chiamato "osc-440" e non trovandolo non mostrerà un 
object box corretto con ingressi e uscite. 


2) D: Va bene. Perché però non mi ha dato un messaggio di errore? 


R: Il messaggio d'errore c'è, e si trova nella Pd window: una finestra che il 
programma utilizza per comunicare con l'utente. Potete richiamarla dal menu 
Window/Pd window oppure tramite la combinazione <C-r>. Nella finestra, tro- 
verete probabilmente questo messaggio: 

“osc-440 

... Couldn't create” 


3) D: lo ho messo uno spazio tra "osc-" e "440", però l'oggetto è privo di 
ingressi e uscite lo stesso! 


R: Questo è un errore più sottile, e capita spesso all'inizio con gli oggetti che 
hanno una tilde (-) alla fine del nome. Probabilmente per scrivere questo 
carattere avete dovuto usare una combinazione di tasti (ad esempio, per Mac 
«alt-5»), e uno dei tasti della combinazione è rimasto premuto mentre avete 
digitato lo spazio (avete ad esempio premuto <alt-spazio>); la combinazione 
non è riconosciuta da Pd che quindi non è in grado di separare il nome dell'og- 
getto dall'argomento. Cancellate lo spazio e riscrivetelo, facendo attenzione a 
premere solo la barra spaziatrice. 


4) D: Non sento alcun suono. 


R: Avete attivato l'audio con <C-/>? Avete alzato il cursore del fader se era 
abbassato? Siete sicuri che il computer non sia in mute, ovvero riuscite a ripro- 
durre dei suoni con altri programmi? Avete controllato che sulla finestra Audio 
Settings (sotto il menù Media) sia stata selezionata la scheda audio giusta? 


Piccolo "manuale di sopravvivenza" per Pd 
In questa sezione daremo alcune informazioni essenziali per muoversi bene 
nell'ambiente Pd. 


COMANDI DA TASTIERA BASILARI 
Innanzitutto rivediamo i comandi da tastiera che abbiamo imparato finora: 


«C-n» serve a creare una nuova Patcher Window, lo spazio di lavoro dove pos- 
siamo realizzare le patch. 


«C-e» serve per alternare la modalità edit alla modalità run nella Patcher 
Window. In edit possiamo assemblare le patch creando gli oggetti e tutti gli altri 


Estratto da "Pure Data: Musica Elettronica e Sound Design" di F. Bianchi, A. Cipriani e M. Giri 
@ 2016 ConTempoNet- Tutti i diritti riservati 


60 Pratica - Paragrafo 1.1 - Installazione e primi passi con Pd 


tipi di text box; in run mode possiamo far funzionare la patch ed interagire con 
gli oggetti grafici di interfaccia, come i number box o l'oggetto [vs.gain-]. 


<C-r> serve per richiamare (qualora non fosse già visibile) la Pd window che 
è una finestra utilizzata dal programma per comunicare con l'utente, e che 
l'utente puó usare per visualizzare brevi messaggi (vedremo piü avanti come). 


«C-1» serve per creare un object box generico, all'interno del quale scriviamo 
una stringa che rappresenta il nome dell'oggetto specifico, seguito dagli even- 
tuali creation arguments. L'object box puó essere anche creato tramite il menu 
Put/Object. 


«C-3» serve per creare un number box, che può essere creato anche attraverso 
il menu Put/Number. 


SELEZIONARE, CANCELLARE E COPIARE 

Per cancellare un cavo o un oggetto bisogna assicurarsi di essere in modalità 
edit12 e poi selezionarlo con il mouse e premere il tasto di cancellazione, detto 
anche Backspace. Possiamo selezionare piü oggetti contemporaneamente 
facendo clic su un punto vuoto della Patcher Window e trascinando il mouse 
in modo da includere gli oggetti da selezionare nell'area di trascinamento. Gli 
oggetti selezionati sono colorati in blu; a questo punto se spostiamo uno degli 
oggetti selezionati spostiamo anche tutti gli altri, oppure se premiamo il tasto di 
cancellazione li cancelliamo tutti, inclusi i cavi che li collegano. 

Per cancellare solo i cavi invece le cose funzionano diversamente: per cancellare 
un singolo cavo è sufficiente selezionarlo con un clic del mouse e premere il 
tasto Backspace. Cancellare invece un gruppo di cavi é impossibile, perché in 
Pd non si possono selezionare gruppi di cavi, bisogna selezionarli e cancellarli 
uno alla volta. 


Per duplicare un oggetto o un gruppo di 
oggetti bisogna selezionarlo o selezionarli e 
premere la combinazione «C-d»: gli ogget- 
ti duplicati vengono posti molto vicino agli 
originali (fig. 1.9) e risultano selezionati; in 
questo modo é possibile spostarli grazie 
alle frecce della tastiera del computer. Per 
far si che lo spostamento sia più rapido si 
puó tenere premuto il tasto SHIFT!3 men- 
tre si usano le frecce: questo meccanismo 
permette di fare un passo di spostamento 
fig. 1.9: duplicare oggetti più lungo. 


12 Ovvero bisogna accertarsi che muovendo il mouse all'interno della patcher window il puntatore 
abbia la forma di una mano. 
13 SHIFT è il tasto delle maiuscole. 
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Per copiare un oggetto o un gruppo di oggetti in un'altra patcher window è suf- 
ficiente selezionare l'oggetto o il gruppo di oggetti poi usare la combinazione 
«C-c» per copiare e <C-v> per incollare, come per qualsiasi editor. 


Se fate un errore (ad esempio cancellate un oggetto al posto di un altro) 
potete annullarlo selezionando il comando undo dal menù Edit (combinazione 
<C-z>) (in italiano il comando si traduce generalmente con annulla). Se poi vi 
accorgete che non era un errore (ad esempio che volevate cancellare proprio 
quell'oggetto) potrete ripristinare la situazione tramite il comando redo (ripri- 
stina) sempre dal menü Edit («SHIFT-C-z»). Attenzione! Pd tiene in memoria 
solo l'ultima operazione compiuta, quindi il comando undo può annullare solo 
l'ultima operazione. Per redo vale lo stesso principio: ripristina solo l'ultima 
operazione. 


LA MODALITÀ AUTOPATCH 

Un'interessante modalità di lavoro messa a disposizione da Pd è l'autopatch 
mode, che permette di creare oggetti già collegati fra loro. Vediamo con un 
esempio pratico come si realizza questa tecnica: aprite una nuova patcher 
window («C-n») e al suo interno create un oggetto [osc- 440] con <C-1>. 
Selezionate l'oggetto e premete nuova- 
mente <C-1>: comparirà un nuovo object 
box generico già collegato ad [osc-] 
ES tramite un patch cord (Fig. 1.10); scrivete 
I [dac-] dentro a questo object box e poi 
fate clic in una parte vuota della patcher 
fig. 1.10: creazione di oggetti window. In questo modo avete creato due 
collegati tramite la modalità oggetti già collegati. Questo sistema fun- 
autopatch ziona solo nei collegamenti fra gli outlet e 

gli inlet di sinistra degli oggetti. 


L=. = 


HELP DI PD 

Questo libro ë autosufficiente: qui troverete tutte le informazioni utili per 
comprendere e usare le patch che via via illustreremo e per utilizzare le diverse 
tecniche di sintesi ed elaborazione del suono con Pd. Se conoscete l'inglese può 
essere utile dare anche un'occhiata al sistema di Help in linea del programma. 
Praticamente ogni oggetto di Pd ha una sua pagina di help dedicata. Per acce- 
dervi è sufficiente, in Edit Mode, fare clic col tasto destro del mouse sull'oggetto 
e scegliere la voce 'Help' dal menu che compare. In Run Mode invece, tenendo 
premuto il tasto CTRL (o Command per il Mac), fate clic col sinistro del mouse 
e scegliete la voce Help. 
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Le pagine di Help spiegano tutte (o quasi) le funzioni di un oggetto e forniscono 
semplici esempi di utilizzo (fig. 1.11). 


- cosine wave oscillator = 
7 
a : N pd dsp 1; . 
The osc- object outputs a cosine wave. If no argument is RE «-Click to start 
metro 


supplied, the input is taken to be an audio signal. With a 
floating-point argument, osc- takes floating-point messages 


to change frequency. ; 
Diis: fi <-Click to stop 


incoming numbers 


change frequency v-- inlet resets phase 


<-- creation argument sets initial frequency 


amplitude controls: 


off 
frequency control 
envelope convert to 
generator 


audio signal 


oscillator 
tabwrite- array99 


: invoked without argument to 
graph the output audio output 


specify audio signal input 
array99 


See also: [Phaser] [os] [Zeezeaa42] 


updated for Pd version 0.33 


fig. 1.11: pagina di Help dell'oggetto [osc-] 


Sotto il menu Help si può anche accedere ad una sorta di Browser che permette 
di navigare all'interno delle pagine della documentazione ufficiale di Pd. Al suo 
interno si può navigare fra le cartelle che contengono le pagine di Help stesse e 
i Manuali scritti da Miller Puckette, il creatore di Pure Data. 


gv ATTIVITÀ 


Create una nuova Patcher Window e riproducete la patch del file 01 01.pd. 
Attenzione a non confondere l'oggetto [vs.number-] con il number box! 
Il primo si crea scrivendo la stringa 'vs.number-" all'interno di un object box 
generico, mentre il secondo si crea con la combinazione «C-3» o dal menu Put/ 
Number. 


® e 0 9 0 oe 6 e 9 0 9 0 0 à 0 e o o 0 o o 0 0 0 o o 0 0 o o o o o o o e e 9 o o e o 0 e e e e e o e e e e 0 0 e 0 e 


(s) 
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II capitolo prosegue con: 


1.2 


1.3 


1.4 


1.5 


1.6 


1.7 


FREQUENZA, AMPIEZZA E FORMA D'ONDA 
Generatori limitati in banda 


VARIAZIONI DI FREQUENZA E AMPIEZZA NEL TEMPO: 
INVILUPPI E GLISSANDI 

Glissandi 

Curve esponenziali e logaritmiche 


RAPPORTO TRA FREQUENZA E INTERVALLO MUSICALE E TRA 
AMPIEZZA E LIVELLO DI PRESSIONE SONORA 

Glissandi “naturali” 

Conversione decibel-ampiezza 

Scala cromatica 


CENNI SULLA GESTIONE DEI FILE CAMPIONATI 
L'oggetto vs.splayer- 
Registrazione su file 


CENNI SUL PANNING 
ALTRE CARATTERISTICHE DI PD 


Messaggi vs. segnali 
L'oggetto cnv 


ATTIVITÀ 
e Correzione di algoritmi, analisi di algoritmi, completamento di algoritmi, sosti- 
tuzione di parti di algoritmi 


VERIFICHE 
e Compiti unitari di reverse engineering 


SUSSIDI DIDATTICI 
e Lista comandi principali - Lista oggetti nativi Pd - Lista oggetti della libreria 
Virtual Sound - Lista messaggi per oggetti specifici - Glossario 
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PROGRAMMIAZIONE CON PD 


IA.1 
IA.2 
IA.3 
IA.4 
IA.5 
IA.6 
IA.7 
IA.8 
IA.9 


OPERATORI BINARI E ORDINE DELLE OPERAZIONI 
GENERAZIONE DI NUMERI CASUALI 

GESTIONE DEL TEMPO: METRO 

SUBPATCH E ABSTRACTION 

ALTRI GENERATORI RANDOM 

LISTE 

IL MESSAGE BOX E GLI ARGOMENTI VARIABILI 
COLLEGAMENTI SENZA FILI 

ARRAY 
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CONTRATTO FORMATIVO 


PREREQUISITI PER IL CAPITOLO 
* CONTENUTI DEL CAP. 1 (TEORIA E PRATICA) 


OBIETTIVI 

ABILITÀ 

* SAPER UTILIZZARE TUTTE LE FUNZIONI DI BASE DEL SOFTWARE PURE DATA RIGUARDANTI | NUMERI 

* SAPER GENERARE E CONTROLLARE SEQUENZE DI NUMERI CASUALI CON POSSIBILE USO DI 
METRONOMO 

* SAPER COSTRUIRE ALGORITMI ALL'INTERNO DI SUBPATCH E ABSTRACTION 

* SAPER GESTIRE LA REPLICAZIONE DI MESSAGGI SU VARIE USCITE 

* SAPER GESTIRE LA COMPOSIZIONE E SCOMPOSIZIONE DI LISTE 

* SAPER GESTIRE L'UTILIZZO DI ARGOMENTI VARIABILI 

* SAPER GESTIRE LA COMUNICAZIONE FRA OGGETTI SENZA L'USO DI CAVI DI COLLEGAMENTO 
VIRTUALI 


CONTENUTI 

* | NUMERI IN PD 

* GENERAZIONE E CONTROLLO DI NUMERI CASUALI CON GLI OGGETTI random, vs.drunk 
ETC. 

* GENERAZIONE DI EVENTI A RITMO REGOLARE MEDIANTE L'OGGETTO metro 

* COSTRUZIONE DI SUBPATCH E ABSTRACTION 

* GESTIONE DI LISTE E ARGOMENTI VARIABILI 

* Uso DEGLI OGGETTI send E receive PER COMUNICAZIONE WIRELESS FRA GLI OGGETTI 


TEMPI - CAP. 1 (TEORIA E PRATICA) + INTERLUDIO A 
AUTODIDATTI 
PER 300 ORE GLOBALI DI STUDIO INDIVIDUALE (VOL. |, TEORIA E PRATICA): 
* CA. 100 oRE 
CORSI 
PER UN CORSO GLOBALE DI 60 ORE IN CLASSE + 120 DI STUDIO INDIVIDUALE 
(voL. |, TEORIA E PRATICA): 
* CA. 16 ORE FRONTALI + 4 DI FEEDBACK 
* CA. 40 DI STUDIO INDIVIDUALE 


ATTIVITÀ 

ATTIVITÀ AL COMPUTER: 

* SOSTITUZIONE DI PARTI DI ALGORITMI, CORREZIONE, COMPLETAMENTO E ANALISI DI ALGORITMI, 
COSTRUZIONE DI NUOVI ALGORITMI 


VERIFICHE 
* COMPITI UNITARI DI REVERSE ENGINEERING 


SUSSIDI DIDATTICI 
* [ISTA OGGETTI NATIVI DI PD — LISTA OGGETTI DELLA LIBRERIA VIRTUAL SOUND - LISTA MES- 
SAGGI PER OGGETTI SPECIFICI - GLOSSARIO 
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In questo primo “interludio” approfondiremo alcuni aspetti della program- 
mazione con Pd: si tratta di informazioni essenziali che ci saranno utili per la 
lettura del resto del libro. Vi consigliamo quindi di non saltarle, a meno che non 
siate già utenti esperti del programma. È altrettanto importante realizzare tutte 
le patch che vi verranno via via proposte. C'è da fare un piccolo sforzo che vi 
permetterà di ottenere grandi risultati. 


IA.1 OPERATORI BINARI E ORDINE DELLE OPERAZIONI 


Installazione e configurazione del sistema 


Come ogni linguaggio di programmazione che si rispetti, anche Pd può svolgere 
diverse operazioni sui numeri: ricreate la semplice patch di figura IA.1 (attenzio- 
ne allo spazio tra ‘+’ e '5?). 

L'oggetto [ +] somma il suo argomento (in 


5 questo caso 5) a qualunque numero riceva 
nel suo inlet: se mandiamo dei numeri 
all'oggetto tramite il number box superiore 
(facendo clic sull'oggetto in run mode e 
ram scrivendo un valore con la tastiera), possia- 
mo vedere il risultato dell'operazione nel 

fig. IA.1: addizione number box inferiore. 


L'ingresso di destra serve a cambiare l'ar- 
gomento: se inviamo un numero a questo ingresso tramite un nuovo number 
box, questo sostituisce l'argomento dell'oggetto [ +] nelle somme che si pro- 
durranno mandando altri numeri all'ingresso di sinistra. 


Aggiungete un number box a destra, come in fig. IA.2. 


la somma viene generata SOLO 
quando si manda un numero 


nell'inlet di sinistra 


questo numero sostituisce 


l'argomento 


il risultato ë la somma del numero che entra 
nell'inlet di sinistra piü il numero che entra 


nell'inlet di destra (che sostituisce l'argomento) 


fig. IA.2: addizione con argomento variabile 
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Se effettuate un po' di prove, noterete che l'operazione viene eseguita solo 
quando entra un numero nell'ingresso di sinistra, non in quello di destra che 
serve invece a sostituire l'argomento. 


Precisiamo meglio questo concetto: i numeri che entrano nei due ingressi 
dell'oggetto [+] vengono memorizzati in due celle di memoria, che chiamere- 
mo variabili interne, che si trovano nell'oggetto stesso. Ogni volta che un nuovo 
numero entra in uno dei due ingressi, la variabile interna corrispondente viene 
aggiornata: il vecchio numero viene cancellato e sostituito con il nuovo. Oltre a 
ciò, quando il numero entra nell'ingresso sinistro viene eseguita l'operazione pro- 
pria dell'oggetto [ +], cioé la somma del contenuto delle due variabili interne. 
Questa é una caratteristica comune alla grande maggioranza degli oggetti di 
Pd che svolge la propria funzione solo quando un messaggio entra nell'ingresso 
di sinistra; i messaggi che entrano dagli altri ingressi servono a modificare gli 
argomenti, ovvero ad aggiornare le variabili interne, o a modificare il compor- 
tamento degli oggetti. 


Nel lessico degli oggetti di Pd, viene definito ca/do l'ingresso di sinistra, che 
generalmente fa compiere l'operazione all'oggetto stesso, mentre vengono 
definiti freddi tutti gli altri ingressi che aggiornano le variabili interne senza 
produrre un output. 

Per riassumere, affinché un'operazione sia eseguita in modo corretto, é essen- 
ziale che vengano inviati prima i dati agli ingressi freddi e poi a quello caldo. 
Per favorire l'ingresso dei dati in modo che l'ultimo ingresso a ricevere sia quello 
a sinistra (caldo), anche l'uscita dei messaggi dagli oggetti avviene da destra a 
sinistra. Osserviamo un esempio con l'oggetto [swap], che abbiamo incontra- 
to alla fine del primo capitolo. Questo oggetto inverte l'ordine di due numeri in 
entrata. Al momento della restituzione verrà inviato prima un numero dall'outlet 
destro, poi dal sinistro (fig. IA.3). 


riceve '20' 


fig. IA.3: ordine di uscita da un oggetto 


Per verificare il funzionamento di questa patch, dopo averla riprodotta fate clic 
prima sul message box a destra ('20") poi su quello a sinistra (‘10’): verranno 
restituiti prima il valore 10 dall'uscita destra e poi il valore 20 da quella di sini- 
stra. 
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L'OGGETTO TRIGGER 


Entrambi questi comportamenti — inlet caldi e freddi e ordine da destra a sinistra 
— non generano ambiguità. Basta tenere presenti queste ‘precedenze’ e non si 
incorre in problemi. Cosa succede invece quando da uno stesso outlet escono 
due patch cords come nell'esempio IA.4? 
Pd stabilisce che ha la precedenza il 
patch cord che è stato creato per primo. 
Nell'esempio, che mostra come calcolare 
il quadrato del numero tre, l'operazione si 
svolge correttamente solo se ë stato creato 
prima il cavo di collegamento destro. In 
questo caso, infatti, all'attivazione del mes- 
sage box viene inviato prima il messaggio 
fig. IA.4: ordine di uscita da '3' all'inlet destro e memorizzato nella cor- 
uno stesso outlet rispondente variabile interna, poi una copia 
dello stesso messaggio viene inviata all'inlet 
sinistro e viene eseguita l'operazione. Se invece venisse creato prima il cavo sini- 
stro, all'attivazione del message box il ‘3’ verrebbe inviato prima all'inlet sinistro, 
e quindi subito eseguito il calcolo: il tre verrebbe moltiplicato per zero perché a 
destra non sarebbe arrivato alcun valore — e si otterrebbe un risultato inatteso. 


Guardando la patch ë impossibile stabilire se sia stata costruita correttamente 
ed ë quindi assolutamente sconsigliabile usare questo tipo di configurazione. 
L'oggetto che permette di determinare con certezza le priorità nell'invio dei 
messaggi é [trigger], che si puó usare anche nella sua forma abbreviata 
[t] (fig. IA.5). 

L'oggetto accetta un numero arbitrario di creation arguments ognuno dei quali 
indica il tipo di messaggio da restituire. Per ognuno degli argomenti viene creato 
un outlet. 

Quando riceve un messaggio dal suo 
unico inlet, [trigger] invia lo stesso da 
tutti i suoi outlet, partendo da quello di 
destra. Nell'esempio vengono creati due 
outlet di tipo numerico (float); quando 
viene ricevuto il messaggio ‘3’, questo 
valore viene immediatamente restituito, 
prima dall'outlet destro, poi dal sinistro. 
In questo modo l'oggetto [*] riceve nel 
giusto ordine i due membri della molti- 
plicazione e può effettuare il calcolo nel 
fig. IA.5: oggetto [trigger] modo corretto. 


e 
NE 
Fh 
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fig. IA.6: conversione di tipo 
con [trigger] 


La necessità di tipizzare gli outlet è moti- 
vata dal fatto che [trigger] può anche 
convertire i tipi di atomi che riceve. In 
figura IA.6 un [trigger] contiene due 
argomenti: il primo, b, abbreviazione di 
bang, indica che qualunque numero entri 
nell'inlet, dalla prima uscita verrà sempre 
restituito un bang mentre il secondo argo- 
mento, f abbreviazione di float, indica 
che dall'uscita destra uscirà il numero che 
[trigger] riceve dall'inlet. 


Nell'esempio in figura il message box invia a [trigger] il numero 3, che viene 
restituito dall'outlet destro, mentre dall'outlet sinistro viene restituito un bang. 


fig. IA.7: rendere caldo 
un ingresso freddo 


In figura IA.7 usiamo il meccanismo della 
conversione per realizzare un semplice 
algoritmo che ‘scalda’ l'inlet freddo di un 
oggetto [+]: quando inviamo l'addendo 
all'inlet sinistro, l'oggetto [+] per sua 
natura esegue l'operazione e restituisce il 
risultato. Quando invece inviamo un valore 
dal number box in alto a destra questo 
invia il valore a [trigger] che prima fa 
uscire il valore stesso dal suo outlet destro, 
memorizzandolo nella corrispondente 
variabile interna, e immediatamente dopo 
invia un bang all'ingresso sinistro di [+], 
che ‘forza’ l'oggetto a produrre il risultato 


addizionando i due valori memorizzati nelle variabili interne. 


Per finire ricapitoliamo i diversi argomenti che l'oggetto [trigger] accetta, 
introducendone alcuni che ancora non conosciamo: 


numero float 
symbol 
bang 


S occur 


DEPTH FIRST 


lista (cioë un messaggio composto da piü atomi) 
anything (questo argomento lascia passare qualunque cosa senza convertirla) 


L'ultimo criterio che regola l'ordine delle operazioni ë quello definito depth 
first. In sostanza questa regola prescrive che un messaggio intraprende un 
solo viaggio alla volta e finché non giunge ad un punto di terminazione non 
ne intraprende un altro. In figura IA.8 il bang iniziale percorre prima il ramo 
destro dell'algoritmo, fino a giungere all'oggetto [print A], poi percorre il 
ramo centrale per giungere a [print B]; infine percorre il ramo sinistro fino 


all'oggetto [print C]. 
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fig. IA.8: il principio depth first 


Facendo clic sul bang in alto vi accorgerete che “a vista d'occhio” i tre bang 
si accendono contemporaneamente perché il viaggio attraverso i tre rami della 
patch avviene in tempi brevissimi. Se osservate la pd window però, potete osser- 
vare che il primo [print] a ricevere il bang è quello etichettato con 'A', poi 
quello con etichetta 'B' e infine l'ultimo a sinistra, con etichetta 'C'. 


Tornando all'oggetto [+] di Pd, vediamo ora una semplice applicazione musi- 
cale: aprite il file IA 01 trasposizione.pd (fig. IA.9). 


nota MIDI (0-127) 


fig. IA.9: file IÀ O1 trasposizione.pd 


In questa patch, ogni volta che viene impostato un valore sul number box in 
alto vengono generate due note, la seconda delle quali si trova sette semitoni 
sopra la prima, ovvero una quinta sopra. | pratica, ogni volta che immettiamo 
un valore nel number box la corrispondente nota MIDI viene inviata all'oggetto 
[mtof£ ] di sinistra che la converte in frequenza. Allo stesso tempo però la stessa 
nota viene inviata ad un sommatore che aggiunge il valore '7' alla nota, ovvero 
aggiunge sette semitoni alla nota di partenza. La somma viene quindi inviata ad 
un secondo oggetto [mtof ]. 
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Tramite il sommatore, quindi, è possibile effettuare la trasposizione delle note 
MIDI ad intervalli arbitrari (cioè a distanze fra due note che possiamo determina- 
re noi). Dopo che i valori MIDI delle due note sono stati convertiti in valori fre- 
quenza, vengono inviati a due oscillatori, [vs.blsquare-] e [vs.blsaw-] 
che eseguono l'intervallo di quinta. Impostate nella patch di fig. IA.9 altri inter- 
valli (terza, cioè quattro semintoni, quarta, ovvero cinque semitoni e così via), 
aggiungete poi un altro sommatore, collegato ad un nuovo [mtof] a sua volta 
collegato ad un oscillatore e fate in modo che ad ogni valore inserito nel number 
box in alto corrisponda un accordo maggiore di tre note: se ad esempio scrivete 
nel number box il valore 60, si ottiene l'accordo 60, 64, 67. 


RAPPRESENTAZIONE DEI NUMERI IN PD E ALTRE OPERAZIONI 


Per approfondire l'uso degli operatori binari è importante capire come i numeri 
sono rappresentati in Pd. A differenza della maggior parte dei linguaggi di pro- 
grammazione, che distingue fra numeri interi e numeri con la virgola, in Pd i 
numeri sono sempre rappresentati come numeri con la virgola, in inglese float 
numbers. 


Questo puó creare dei problemi quando si devono svolgere operazioni che 
richiedano l'uso dei numeri interi. Nell'esempio a sinistra in figura IA.10 un 
programmatore si aspetterebbe una divisione fra due numeri interi (l'oggetto 
[/] ovviamente è deputato all'esecuzione della operazione di divisione), che in 
genere restituisce un risultato intero. In Pd invece i due numeri in entrata sono 
considerati numeri di tipo float e il risultato è esso stesso un float. Per effet- 
tuare una divisione intera (con un risultato di tipo intero) bisogna convertire in 
intero il risultato con l'oggetto [int]. Ad essere precisi [int] elimina la parte 
frazionaria di un float, restituendo nuovamente un float (vedi la parte destra in 
fig. IA.10). 

L'oggetto [int] e il suo omologo per i numeri con virgola [ float], rispetti- 


divisione tra numeri divisione tra interi 


con la virgola 


Pa I 
[2.333 


elimina la parte frazionaria 


di un numero 


fig. IA.10: divisione 


vamente abbreviabili in [i] ed [£], hanno anche un'altra funzione importante: 
mantengono in memoria l'ultimo valore ricevuto dall'inlet destro o sinistro. Se 
ad esempio inviamo ad uno di questi oggetti un valore all'entrata destra, questo 
può essere restituito dall'outlet inviando un bang all'inlet sinistro (fig. IA.11). 
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con il bang chiedo all'oggetto 
di restituire dall'outlet 
il valore precedentemente 
memorizzato 


fig IA.11: oggetto [ float] 


Gli operatori binari che abbiamo esaminato ([+],[*] e [/]) insieme a [=] 
e [pow], costituiscono il gruppo degli operatori binari aritmetici, che avremo 
occasione di incontrare spessissimo nel corso di questo testo. Aprite una nuova 
patcher window, create alcuni oggetti per le operazioni aritmetiche e verifica- 
tene il comportamento. 


Per finire, mostriamo un semplice esempio di utilizzo di operatori binari per 
costruire un meccanismo che, agendo su due oscillatori, usi una frequen- 
za per il primo e la trasposizione alla quinta giusta per l'altro. Aprite il file 
IA 02 quinte.pd (fig. IA.12). 


nota MIDI 


fig. IA.12: file IA_02.quinte.pd 


Nella patch osserviamo che la nota MIDI inserita tramite il number box a sinistra 
viene trasformata in frequenza tramite [mto£] e inviata ad un oscillatore a 
onde quadre limitato in banda ([vs.blsquare-]); questa frequenza viene 
inoltre moltiplicata per 3/2, in modo da ottenere la frequenza che si trova 
una quinta sopra, e inviata ad un oscillatore a dente di sega limitato in banda 
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([vs.blsaw-]). L'uscita dell'oggetto [mtof ] quindi si sdoppia, un cavo va al 
number box sinistro mentre l'altro cavo va all'oggetto [*] con argomento 3. 


Se confrontate le figure IA.9 e IA.12 noterete che la frequenza della nota che 
si trova una quinta sopra è leggermente diversa (e di conseguenza è diverso 
anche il timbro complessivo). 

Tramite i due [mtof] infatti abbiamo calcolato un intervallo di quinta tem- 
perata (quella che si usa normalmente nella musica occidentale) che é esatta- 
mente di sette semitoni temperati; tramite il rapporto 3/2 invece calcoliamo 
una quinta naturale che é piü larga di quella temperata di circa due cents 
(centesimi di semitono temperato). 


Per sapere quali e quanti sono gli operatori binari potete aprire il file help- 
intro.pd, a cui si accede tramite il menu Help/List of objects, che mostra l'e- 
lenco con tutti gli oggetti di Pd (fig. IA.13): è un buon punto di partenza per 
conoscere gli oggetti di Pd e la loro funzione. 


The following is a list of built-in objects in Pd. (Not 
included in this list are messages, atoms, graphs, etc. 
which aren't typed into object boxes but come straight off 
the "add" menu.) Right-click (or control-click on a 
Macintosh) on any object to get its "help window". 


y 

w 

=] 

Q 
I 


output a bang message 


store and recall a number 


Fh 

c 

o 

p 

e 
1 


store and recall a symbol 


i 


n: - store and recall an integer 


send a message to a named object 


catch "sent" messages 


H 

Š 

(0) 

H- 

< 

(o) 
I 


- test for matching numbers or symbols 

- route messages according to first element 
- make compound messages 

- get elements of compound messages 

- sequence and convert messagess 
interruptible message connection 

- part a numeric stream 

- looping mechanism 


- print out messages 


"ol EAEL if cil etl'tiintlo 
"5| sjlolr'oilnilsimeiol mo 
p. æ mi e o le l = 
Birmjojiuljmli gei scio 
+j Hita ola |l a oa 

Ho e 
H 
' 


makefilename - format a symbol with a variable field 
[range] - remove repeated numbers from a stream 
[Swap] - swap two numbers 

[alue] - shared numeric value 

[ist] - manipulate lists 
— TIME -——————————————————— 
- send a message after a time delay 

metro - send a message periodically 


fig. IA.13: parte del file help-intro.pd 


C.) 
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II capitolo prosegue con: 


IA.2 GENERAZIONE DI NUMERI CASUALI 
IA.3 GESTIONE DEL TEMPO: METRO 
IA.4 SUBPATCH E ABSTRACTION 
Abstraction 
Graph-on-parent 
IA.5 ALTRI GENERATORI RANDOM 
IA.6 LISTE 
Gli oggetti pack e unpack 
Gli oggetti list append e list prepend 
Altri oggetti per manipolare liste 
IA.7 IL MESSAGE BOX E GLI ARGOMENTI VARIABILI 
II messaggio di comando ”set” 
Gli argomenti variabili: il segno del dollaro ($) 
IA.9 ARRAY 
L'oggetto vs.uzi 
L'oggetto tabwrite 
Inviluppi 
Inviluppi prefabbricati 
IA.10 SEND E RECEIVE 
ATTIVITÀ 


e Analisi di algoritmi, completamento di algoritmi, sostituzione di parti di algorit- 
mi, correzione di algoritmi 


VERIFICHE 
e Compiti unitari di reverse engineering 


SUSSIDI DIDATTICI 
e Lista oggetti nativi Pd - Lista oggetti della libreria Virtual Sound - Lista mes- 
saggi per oggetti specifici - Glossario 
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SINTESI ADDITIVA E SINTESI VETTORIALE 


2.1 SINTESI ADDITIVA A SPETTRO FISSO 

2.2 BATTIMENTI 

2.3 DISSOLVENZA INCROCIATA DI TABELLE: SINTESI VETTORIALE 
2.4 SINTESI ADDITIVA A SPETTRO VARIABILE 
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CONTRATTO FORMATIVO 


PREREQUISITI PER IL CAPITOLO 
e CONTENUTI DEL CAP. 1 (TEORIA) 


OBIETTIVI 

CONOSCENZE 

e CONOSCERE LA TEORIA DELLA SOMMA DI ONDE (FASE, INTERFERENZA COSTRUTTIVA, 
DISTRUTTIVA ETC.) 

* CONOSCERE LA TEORIA E GLI UTILIZZI DI BASE DELLA SINTESI ADDITIVA A SPETTRO FISSO E SPETTRO 
VARIABILE, A SPETTRO ARMONICO E INARMONICO 

e CONOSCERE IL RAPPORTO FRA FASE E BATTIMENTI 

e CONOSCERE IL MODO IN CUI SI UTILIZZANO LE TABELLE E IN CUI AVVIENE L'INTERPOLAZIONE 

* CONOSCERE LA TEORIA E GLI UTILIZZI DI BASE DELLA SINTESI VETTORIALE 

ABILITÀ 

* SAPER INDIVIDUARE ALL'ASCOLTO LE CARATTERISTICHE DI BASE DEI SUONI ARMONICI E INARMO- 
NICI 

* SAPER RICONOSCERE ALL'ASCOLTO | BATTIMENTI 

* SAPER INDIVIDUARE LE VARIE FASI DELL'INVILUPPO DI UN SUONO E SAPERNE DESCRIVERE LE 
CARATTERISTICHE 


CONTENUTI 

* SINTESI ADDITIVA A SPETTRO FISSO E VARIABILE 
* SUONI ARMONICI E INARMONICI 

e FASE E BATTIMENTI 

* INTERPOLAZIONE 

* SINTESI VETTORIALE 


TEMPI - CAP. 2 (TEORIA E PRATICA) 

AUTODIDATTI 
PER 300 ORE GLOBALI DI STUDIO INDIVIDUALE (VOL. |, TEORIA E PRATICA): 

* CA. 60 ORE 

CORSI 
PER UN CORSO GLOBALE DI 60 ORE IN CLASSE + 120 DI STUDIO INDIVIDUALE 
(VOL. |, TEORIA E PRATICA): 

® CA. 10 ORE FRONTALI + 2 DI FEEDBACK 

* CA. 24 DI STUDIO INDIVIDUALE 


ATTIVITÀ 
ESEMPI INTERATTIVI 


VERIFICHE 
TEST A RISPOSTE BREVI 
TEST CON ASCOLTO E ANALISI 


SUSSIDI DIDATTICI 
CONCETTI DI BASE - GLOSSARIO - DISCOGRAFIA - UN PÓ DI STORIA 
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2.1 SINTESI ADDITIVA A SPETTRO FISSO 


II suono prodotto da uno strumento acustico o il suono in generale ë propria- 
mente un'oscillazione complessa esprimibile attraverso un insieme di più vibra- 
zioni elementari che vengono prodotte contemporaneamente dallo strumento 
stesso: la somma di queste diverse vibrazioni contribuisce in modo determinante 
al timbro percepito e ne determina quindi la forma d'onda. Ogni suono può 
quindi essere scomposto in sinusoidi che, come abbiamo detto nel capitolo 
precedente, costituiscono il mattone fondamentale con cui é possibile costruire 
ogni altra forma d'onda. Ognuna di queste sinusoidi, o componenti del suono, 
ha una propria frequenza, ampiezza e fase. L'insieme delle frequenze, ampiez- 
ze e fasi delle sinusoidi che formano un determinato suono è definito spettro 
sonoro: vedremo più avanti come può essere rappresentato graficamente. 
Non solo i suoni naturali, ma anche i suoni sintetici possono essere scomposti 
in un insieme di sinusoidi: le forme d'onda che abbiamo descritto nel paragrafo 
1.2, quindi, hanno ciascuna un diverso spettro sonoro, ognuna contiene cioè 
una diversa mistura (combinazione) di sinusoidi (ad eccezione ovviamente della 
forma d'onda sinusoidale che contiene soltanto sé stessa!). 


SPETTRO E FORMA D'ONDA 


Spettro e forma d'onda sono due modi differenti per descrivere un suono. La 
forma d'onda è la rappresentazione grafica dell'ampiezza in funzione del tem- 
po.! Nel grafico in figura 2.1 possiamo osservare la forma d'onda di un suono 
complesso in cui sull'asse delle x abbiamo il tempo, sull'asse delle y l'ampiez- 
za; notiamo che la forma d'onda di questo suono è bipolare, cioè i suoi valori 
d'ampiezza oscillano al di sopra e al di sotto dello zero. Questa è una rappresen- 
tazione grafica nel dominio del tempo (time domain), vengono cioè tracciate 
tutte le ampiezze istantanee che vanno a formare, istante dopo istante la forma 
d'onda del suono complesso. 


0.5 


ampiezza 


0 1 2 3 4 5 6 7 8 9 10 
tempo in msec > 


fig. 2.1: forma d'onda di un suono complesso 


1 Nel caso di suoni periodici la forma d'onda può essere rappresentata da un singolo ciclo. 
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Nella fig. 2.2a vediamo invece come si può scomporre in sinusoidi il suono 
complesso appena osservato: abbiamo infatti quattro sinusoidi con frequenza e 
ampiezza diverse, che sommate costituiscono il suono complesso rappresentato 
nel grafico precedente. 


amp 


amp 


amp 


amp 


Di l l l l l l 1 l l l 
0 1 2 3 4 5 6 T 8 9 10 


tempo in msec — 


fig. 2.2a: scomposizione in sinusoidi di un suono complesso 


Se vogliamo “fotografare” in modo più chiaro le varie frequenze di questo suono e 
la loro ampiezza, possiamo affidarci ad un grafico dello spettro sonoro, cioè la rap- 
presentazione dell'ampiezza delle componenti in funzione della frequenza (ovvero 
nel dominio della frequenza o frequency domain). In questo caso sull'asse delle 
x abbiamo i valori di frequenza, sull'asse delle y i valori d'ampiezza. La figura 2.2b 
mostra le ampiezze di picco di ciascuna componente presente nel segnale. 


ampiezza 


AO NEP NEM NEP NE 100 a 0 1000 400,999 
frequenza in Hz 


fig. 2.2b: spettro sonoro 
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Per vedere l'andamento nel tempo delle componenti di un suono possiamo 
usare anche il sonogramma, che ci mostra sull'asse delle y le frequenze e in 
quello delle x il tempo (fig. 2.2c). Le linee corrispondenti alle frequenze delle 
componenti sono piü o meno marcate in funzione della loro ampiezza. In que- 
sto caso abbiamo 4 linee rette, perché si tratta di uno spettro fisso. 


1200 


900 


frequenza in Hz 


600 


300 


tempo — 


fig. 2.2c: sonogramma (o spettrogramma) 


Adesso consideriamo il processo opposto, quello cioé in cui, invece di scom- 
porre un suono complesso in sinusoidi, partiamo dalle singole sinusoidi e 
creiamo un suono complesso. La tecnica che ci permette di creare qualunque 
forma d'onda partendo dalla somma di sinusoidi si chiama sintesi additiva 
(fig. 2.3). 


fig. 2.3: somma di segnali in uscita da oscillatori sinusoidali 
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In fig. 2.4 sono mostrate due onde sonore, A e B, e la loro somma C. 


tempo in msec ——» 


fig. 2.4: rappresentazione grafica di una somma di sinusoidi 


Come si puó facilmente verificare, le ampiezze istantanee dell'onda C sono 
ottenute sommando punto per punto le ampiezze istantanee dell'onda A a 
quelle dell'onda B. Istante per istante i valori dell'ampiezza delle diverse onde si 
sommano algebricamente, cioè con il loro segno, positivo o negativo. Nel caso 
in cui le ampiezze di A e B, in un dato istante, siano entrambe positive o entram- 
be negative, il valore assoluto di ampiezza di C risulterà maggiore di ciascuna 
delle singole componenti, si otterrà cioé un'interferenza costruttiva, ad es. 


A = -03 
B = +0.2 
C = -0.5 


Nel caso in cui invece le ampiezze di A e B, in un dato istante, siano una positiva e 
l'altra negativa, il valore assoluto della loro somma algebrica C sarà minore di alme- 
no una delle due componenti, e si avrà perciò un'interferenza distruttiva, ad es. 


A = 0.3 
B = -0.1 
C = 02 
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“La maggior parte, anzi la quasi totalità, dei suoni che udiamo nel mondo reale 
non è composta da suoni puri, ma da suoni complessi, cioè suoni scomponibili 
in una maggiore o minore quantità di suoni puri; questi vengono detti compo- 
nenti del suono complesso. Per meglio comprendere questo fenomeno, stabilia- 
mo un'analogia con l'ottica. È noto come alcuni colori siano puri, cioè non ulte- 
riormente scomponibili (rosso, arancio, giallo, fino al violetto). A ciascuno di essi 
corrisponde una certa lunghezza d'onda del raggio luminoso. Nel caso in cui sia 
presente soltanto uno dei colori puri, il prisma, che scompone la luce bianca nei 
sette colori dello spettro luminoso, mostrerà solamente quella componente. La 
medesima cosa avviene per il suono. A una certa lunghezza d'onda? del suono 
corrisponde una certa altezza percepita. Se non è presente contemporaneamen- 
te nessun'altra frequenza, il suono sarà puro. Un suono puro, come sappiamo, 
ha forma d'onda sinusoidale." 

(Bianchini, R., Cipriani, A., 2001, pp. 69-70) 


Le componenti di un suono complesso possono avere frequenze che sono mul- 
tipli interi della frequenza della componente più grave. In questo caso la com- 
ponente più grave si chiama fondamentale e le altre si chiamano componenti 
armoniche (ad esempio, fondamentale = 100 Hz, altre componenti = 200 Hz, 
300 Hz, 400 Hz etc.) La componente che ha una frequenza doppia rispetto 
a quella della fondamentale si chiama seconda armonica; la componente di 
frequenza tripla della fondamentale viene detta terza armonica etc. Quando, 
come in questo caso, le componenti del suono sono multipli interi della fon- 
damentale il suono si dice armonico. Notiamo che in un suono armonico la 
frequenza della fondamentale rappresenta il massimo comun divisore delle 
frequenze di tutte le altre componenti: è cioè il massimo numero che divide 
esattamente (senza resto) tutte le frequenze. 


® e e 0 e e è e o è e o e e è e o è e è e o è e o è e è e o è e e e o è e e e e e e e e e e e e e e e e 0 e 0 e 00 


ESEMPIO INTERATTIVO 2A ° COMPONENTI ARMONICHE vB 


Se i suoni puri che compongono un suono complesso non sono multipli interi 
della componente più grave, abbiamo un suono inarmonico e le componenti 
prendono il nome di... 


(...) 


2 “La lunghezza di un ciclo si dice lunghezza d'onda e si misura in metri [m] o in centimetri [cm]. 
Questo ë lo spazio che un ciclo occupa fisicamente nell'aria, e se il suono fosse visibile potrebbe 
facilmente essere misurato, per esempio con un metro." (Bianchini, R. 2003) 
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II capitolo prosegue con: 
La fase 
Spettri armonici e inarmonici 
Periodico/aperiodico, armonico/inarmonico 
Interpolazione nella lettura di tabelle 
2.2 BATTIMENTI 
2.3 DISSOLVENZA INCROCIATA DI TABELLE: SINTESI VETTORIALE 
2.4 SINTESI ADDITIVA A SPETTRO VARIABILE 


ATTIVITÀ 
e Esempi interattivi 


VERIFICHE 
e Test a risposte brevi 
e Test con ascolto e analisi 


SUSSIDI DIDATTICI 
e Concetti di base - Glossario - Discografia - Un po' di storia 
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2P 


SINTESI ADDITIVA 
E SINTESI VETTORIALE 


2.1 SINTESI ADDITIVA A SPETTRO FISSO 

2.2 BATTIMENTI 

2.3 DISSOLVENZA INCROCIATA DI ARRAY: SINTESI VETTORIALE 
2.4 SINTESI ADDITIVA A SPETTRO VARIABILE 
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CONTRATTO FORMATIVO 


PREREQUISITI PER IL CAPITOLO 
e CAP. 1 (TEORIA E PRATICA), CAP.2 (TEORIA), INTERLUDIO A 


OBIETTIVI 

ABILITÀ 

* SAPER SINTETIZZARE UN SUONO COMPLESSO PARTENDO DA SEMPLICI SINUSOIDI 

e SAPER SINTETIZZARE SUONI ARMONICI E INARMONICI IN SINTESI ADDITIVA E TABELLARE E TRA- 
SFORMARE GLI UNI NEGLI ALTRI E VICEVERSA TRAMITE CONTROLLI D'AMPIEZZA E FREQUENZA 

* SAPER REALIZZARE FORME D'ONDA TRIANGOLARI, QUADRE O A DENTE DI SEGA APPROSSIMATE 
MEDIANTE ADDIZIONE DI COMPONENTI ARMONICHE SINUSOIDALI 

e SAPER CONTROLLARE | BATTIMENTI FRA DUE SUONI SINUSOIDALI O ARMONICI 

* SAPER SINTETIZZARE SUONI IN SINTESI VETTORIALE 

COMPETENZE 

* SAPER REALIZZARE UN BREVE STUDIO SONORO BASATO SULLE TECNICHE DI SINTESI ADDITIVA E 
MEMORIZZARLO SU FILE AUDIO. 


CONTENUTI 
* SINTESI ADDITIVA A SPETTRO FISSO E VARIABILE 
* SUONI ARMONICI E INARMONICI 

* FASE E BATTIMENTI 

* INTERPOLAZIONE 

* SINTESI VETTORIALE 


TEMPI - CAP. 2 (TEORIA E PRATICA) 
AUTODIDATTI 
PER 300 ORE GLOBALI DI STUDIO INDIVIDUALE (VOL. |, TEORIA E PRATICA): 
* CA. 60 ORE 
CORSI 
PER UN CORSO GLOBALE DI 60 ORE IN CLASSE + 120 DI STUDIO INDIVIDUALE 
(VOL. |, TEORIA E PRATICA): 
® CA. 10 ORE FRONTALI + 2 DI FEEDBACK 
® CA. 24 DI STUDIO INDIVIDUALE 


ATTIVITÀ 
* ATTIVITÀ AL COMPUTER: SOSTITUZIONE DI PARTI DI ALGORITMI, CORREZIONE, COMPLETAMENTO 
E ANALISI DI ALGORITMI, COSTRUZIONE DI NUOVI ALGORITMI 


VERIFICHE 
* REALIZZAZIONE DI UNO STUDIO BREVE 
* COMPITI UNITARI DI REVERSE ENGINEERING 


SUSSIDI DIDATTICI 
* LISTA OGGETTI NATIVI DI PD — LISTA OGGETTI DELLA LIBRERIA VIRTUAL SOUND - LISTA MESSAGGI 
PER OGGETTI SPECIFICI 
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2.1 SINTESI ADDITIVA A SPETTRO FISSO 


La prima patch di questo capitolo realizza un algoritmo di sintesi additiva a spet- 
tro armonico. Come sappiamo si dice armonico uno spettro in cui le frequenze 
sono multipli interi della frequenza fondamentale. La patch fa riferimento alla 
figura 2.12 del paragrafo 2.1 della teoria, in cui 10 oscillatori vengono sommati 
tramite un miscelatore. 

Ogni oscillatore riceve un valore che imposta la frequenza e un altro che ne defi- 
nisce l'ampiezza. Per avere uno spettro armonico sarà sufficiente scegliere una 
frequenza fondamentale e moltiplicarla per una serie di numeri interi successivi. 
In questo modo il primo oscillatore avrà la frequenza fondamentale, il secondo 
avrà frequenza doppia, il terzo tripla e così via. 

La figura 2.1 mostra la patch, contenuta nel file 02_01_spettro_armonico.pd. 


frequenza fondamentale 


frequenze 


liste di ampiezze: 


; 

amps 1 0.5 0.333 0.25 0.2 0.167 0.143 0.125 0.11 0.1 
; 

amps 1 0 0.333 0 0.2 0 0.143 0 0.11 0 

; 

amps 0.1 0.11 0.125 0.143 0.167 0.2 0.25 0.333 0.5 1 
; 

amps 0.2000001 0 0.1 0.05 


fig. 2.1: file 02 01. spettro armonico.pd 


Il number box in alto a sinistra permette di impostare la frequenza fondamen- 
tale, che entra direttamente nel primo [osc- ]. Tutti gli altri oscillatori ricevono 
la stessa frequenza moltiplicata per un intero tramite l'oggetto [ * ]. Il segnale 
in uscita da ogni [osc- ] è collegato a un [ *- ]: in questo modo il segnale può 
essere riscalato in ampiezza: ogni [ *- ] riceve infatti il fattore di riscalamento da 
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un number box. Infine, i 10 segnali vengono inviati all'inlet sinistro di un [ *—] 
con argomento 0.1, quindi la somma dei segnali viene moltiplicata per 0.1, in 
modo che il segnale risultante non superi la soglia massima! .. 


Questo tipo di algoritmo definisce uno spettro fisso, perché le frequenze varia- 
no al variare della fondamentale, ma mantengono sempre lo stesso rapporto 
fra loro. Le ampiezze invece possono essere cambiate a piacimento, in modo 
da creare timbri diversi. | message box in basso contengono liste di ampiezze 
prestabilite, che vengono inviate all'oggetto [receive] ([r]) con argomento 
amps e poi “spacchettate” tramite [unpack]. 


Nulla impedisce di impostare manualmente le ampiezze agendo con il mouse 
sui singoli number box. L'unica accortezza è quella di agire col mouse tenendo 
premuto il tasto SHIFT, per generare valori decimali e non eccedere 1. Ascoltate 
i diversi timbri facendo clic sui message box dopo aver attivato il motore audio. 


In basso a destra della patch trovate un oggetto [switch-] collegato ad un 
toggle: si usa per attivare o disattivare l'audio solo nella patch in cui risiede e 
in tutte le subpatch e le abstraction che a quella patch fanno riferimento?. In 
sostanza con [switch-] potete decidere quali patch far "suonare" e quali 
lasciare mute, evitando cosi fastidiose sovrapposizioni dell'audio. Quando il tog- 
gle invia il messaggio ‘1’, l'audio viene attivato nella patch in cui si trova; al con- 
trario, con il messaggio 'O', lo disattiva, lasciando attive le altre. Naturalmente, 
affinché [switch-] possa svolgere il suo compito, il motore audio generale 
deve essere attivo3. 


Per evitare ridondanze grafiche, l'oggetto [switch-] non compare nelle 
successive figure di questo testo, ma le patch allegate ne sono provviste. Può 
essere utile, quando copiate gli algoritmi di questo libro, corredarli con l'oggetto 
[switch-] collegato ad un toggle, in modo da poter gestire comodamen- 
te l'audio distribuito fra le patch aperte. L'unica accortezza è che l'oggetto 
[switch-] sia creato prima dell'ultimo oggetto con la tilde della patch. In caso 
contrario, [switch-] non funzionerà, a meno di non salvare con un nome la 
patch in un file. 


1 Ogni oscillatore restituisce un segnale che puó avere al massimo ampiezza pari a 1. Se tutti i 
segnali escono alla massima ampiezza, la somma degli oscillatori sarà un segnale di ampiezza 10. 
Moltiplicare questo segnale per 0.1 garantisce che la somma possa dare al massimo un segnale di 
ampiezza pari a 1. 

2 In realtà l'oggetto [switch-] svolge anche altre funzioni, ma queste saranno esaminate 
Successivamente. 

3 per attivare il motore audio, come sempre, si usa la combinazione da tastiera <C-/>. 
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ATTIVITÀ A} 


1. Usando la patch 02_01_spettro_armonico_fisso.pd create due nuove 
liste per le ampiezze in due nuovi message box, uno con tutte le ampiezze 
delle armoniche dispari a 1 e le pari a 0 e l'altro con le armoniche pari a 1 
e le dispari a 0, qual ë la differenza più evidente? E perché? 


2. Sempre con la patch 02_01_spettro_armonico_fisso.pd, (facendo 
riferimento alla questione della fondamentale mancante o frequenza 
fantasma, trattata nel par. 2.1 della teoria) partite da uno spettro in cui 
tutte le ampiezze delle armoniche siano a 1, poi azzerate l'ampiezza della 
fondamentale. Sentirete ancora uno spettro la cui fondamentale è pari alla 
frequenza che abbiamo azzerato. Provate a ridurre a zero l'ampiezza delle 
armoniche successive, una ad una. A che punto non si percepisce più la 
fondamentale? 


LA FASE 


Come avrete osservato, l'oggetto [osc-] possiede due inlet: il sinistro, che 
è quello che abbiamo usato fino ad ora, serve ad impostare la frequenza 
dell'oscillatore e può ricevere un messaggio o un segnale. L'inlet destro invece, 
consente di impostare la fase e riceve solo messaggi. Il valore che si invia a 
questo inlet è un decimale compreso fra zero e uno, che rappresenta la fase 
normalizzata. Un valore di zero corrisponde ad un angolo di 0° o di 0 radianti, 
un valore di 0.25 corrisponde a 90° (7/2 radianti); 0.5 equivale a 180°, quindi 
a z radianti e cosi via. Il valore di 1 corrisponde al termine di un ciclo, quindi 
360°, che è uguale a 0°. 


Quando si invia un messaggio all'inlet destro di [osc-] si “costringe” il 
generatore a ricominciare la forma d'onda a partire dal punto indicato nel 
messaggio stesso. Ad esempio il messaggio ‘0’ produce la generazione della 
forma d'onda a partire dalla fase che corrisponde al valore 0. 


Riproducete la patch in figura 2.2, attivate il motore audio e fate clic ripetuta- 
mente sul message box per reimpostare la fase: potrete udire un click ogni volta 
che attivate il message box perché l'esecuzione della forma d'onda viene inter- 
rotta per essere rieseguita dall'inizio (cioè dal valore indicato nel message box). 


fig. 2.2: reimpostazione della fase in un oggetto [osc-] 
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La figura 2.3 mostra quello che accade in un oscillatore quando viene eseguita 
la reimpostazione (in inglese reset) della fase. Appena il reset viene attivato 
tramite il message box, il generatore riesegue la forma d'onda a partire dal 
punto indicato dal messaggio, generando un punto di disconinuità che produ- 
ce un click udibile. In questo caso l'onda viene ripristinata con il messaggio ‘0’ 
(come in fig. 2.2): tale messaggio costringe l'oscillatore a generare la forma 
d'onda ricominciando dall'inizio. 

L'inizio di un ciclo di una sinusoide, come sappiamo dal cap. 1.2 della parte 
di teoria, corrisponde a un valore di ampiezza pari a 0. Perché, al contrario, 
il valore di ampiezza in corrispondenza del reset che vedete nell'immagine è 
1? Perché l'oggetto [osc-] in realtà non segue l'andamento della funzione 
seno, bensì quello della funzione coseno, il cui inizio di ciclo corrisponde al 
valore massimo di ampiezza. 


reset 
I 


v 
/N Z 

fig. 2.3: rappresentazione grafica del punto di discontinuità generato dal reset 
della fase 


osc_440_hz 


Usata in questo modo, la fase non ë un parametro molto interessante. Lo 
diventa invece quando si mettono in relazione due onde con la stessa frequen- 
za che vengono sommate fra loro. Quando le due onde sono perfettamente 
in fase, la somma sarà un segnale con la stessa forma d'onda, ma di ampiezza 
doppia. 


Copiate la patch in figura 2.4, attivate il motore audio e fate click sul message 
box a sinistra, etichettato con ‘in fase’: entrambi gli oscillatori subiscono nello 
stesso istante un reset della fase con lo stesso valore e la loro somma è rap- 
presentata da una nuova forma d'onda con ampiezza doppia. 


Cosa succede se invece fate clic sul number box etichettato con ‘opposizione 
di fase'? Il generatore a sinistra subisce un reset della fase che lo riporta allo 
stato iniziale, quello a destra subisce ugualmente un reset, ma la nuova onda 
generata inizierà il suo periodo dal valore di fase 0.5, che corrisponde a 180°. 
Questo valore produce un onda in opposizione di fase rispetto all'altra, quindi, 
quando i valori delle due onde si sommano, istante per istante, generano un 
segnale costante pari a 0: non si sente più niente. 
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in opposizione di fase 


fig. 2.4: reset della fase in due oscillatori 


Ora aprite il file 02_02_fase.pd, mostrato in figura 2.5. La fase dell'oscillatore 
sinistro viene sempre ‘resettata’ a 0, mentre quella destra può essere cambiata 
tramite il number box in alto. Al variare della fase, un bang scrive la forma d'on- 
da anche nei tre array che mostrano le singole onde e l'onda risultante. Quando 
impostate a 0.5 la fase dell'oscillatore destro, l'onda risultante è un segnale 
costante pari a 0. Quando invece la fase è prossima a 0 o a 1, l'onda risultante 
eccede i limiti di -1 e 1. Se provate a cambiare i valori della fase — dopo aver 
attivato il motore audio — vi accorgerete che il comportamento è ciclico: quando 
il valore è prossimo a 0.5, 1.5, 2.5 e così via le due onde si annullano; quando il 
valore è pari ad un numero intero — 0, 1, 2, 3 e così via — la somma è un segnale 
di ampiezza doppia rispetto alle singole onde. Questa ciclicità dipende dal fatto 
che un valore di fase pari a 1 reimposta l'onda e la fa ripartire dal valore di 360°, 
che corrispondere a un angolo di 0°. Lo stesso vale per ogni multiplo intero di 1. 


fase del secondo oscillatore 


fig. 2.5: file 02_02_fase.pd 


Estratto da “Pure Data: Musica Elettronica e Sound Design” di F. Bianchi, A. Cipriani e M. Giri 
© 2016 ConTempoNet- Tutti i diritti riservati 


230 Pratica - Paragrafo 2.1 - Sintesi additiva a spettro fisso 


A differenza di [osc- ], l'oggetto [vs.osc- ] consente di gestire la fase attra- 
verso un segnale inviato all'ingresso destro. Vediamo come si può utilizzare, 
ricostruendo la patch di fig. 2.6. 


fig. 2.6: oscillatore guidato da un [phasor-] 


Qui abbiamo un [vs.osc-] a 0 Hz (dal momento che non ha nessun argo- 
mento e nessun messaggio numerico all'ingresso di sinistra) la cui fase viene 
modificata da un [phasor- ] che nell'immagine ha una frequenza di 0 Hz (è 
quindi fermo). Osservando gli oscilloscopi vediamo che [phasor-] genera un 
flusso di campioni di valore 0 (ë quindi fermo all'inizio del suo ciclo), e [vs. 
osc- ] genera un flusso di campioni di valore 1 (anche se non si vede perché 
corrisponde al lato superiore del rettangolo di [vs.scope- ]); è anch'esso 
quindi fermo all'inizio del suo ciclo. 

Adesso diamo al [phasor-] una frequenza maggiore di 0, ad esempio 400 
Hz (vedi fig. 2.7). 


Provate a ricostruire questa patch: l'oggetto [phasor-] controlla in modo 
continuo la fase di [vs.osc-] facendolo oscillare alla sua stessa frequenza e 
con la sua stessa fase. Come sappiamo dal par. 1.2, infatti, [phasor-] genera 
rampe che vanno da 0 a 1: queste rampe, applicate alla fase di [vs.osc-], ne 
provocano l'oscillazione (e questo ci spiega il motivo per cui l'oggetto [pha- 
sor~] si chiama così: una delle sue funzioni principali è guidare la fase di un 
altro oggetto). 


(...) 
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II capitolo prosegue con: 


Uso di array per gli oscillatori 
Spettro fisso inarmonico 


2.2 BATTIMENTI 
Battimenti ritmici 
Battimenti armonici 


2.3 DISSOLVENZA INCROCIATA DI ARRAY: SINTESI VETTORIALE 


2.4 SINTESI ADDITIVA A SPETTRO VARIABILE 
vs.oscbank-: un banco di oscillatori 
II controllo mediante mascheratura 


ATTIVITÀ 
e Analisi di algoritmi, completamento di algoritmi, sostituzione di parti di algorit- 
mi, correzione di algoritmi 


VERIFICHE 
e Compiti unitari di reverse engineering, Realizzazione di uno studio breve 


SUSSIDI DIDATTICI 
e Lista oggetti nativi Pd - Lista oggetti della libreria Virtual Sound - Lista mes- 
saggi per oggetti specifici 
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3T 


GENERATORI DI RUMORE, 
FILTRI E SINTESI SOTTRATTIVA 


3.1 SORGENTI PER LA SINTESI SOTTRATTIVA 

3.2 FILTRI PASSA-BASSO, PASSA-ALTO, PASSA-BANDA ED 
ELIMINA-BANDA 

3.3 IL FATTORE Q O FATTORE DI RISONANZA 

3.4 GLI ORDINI DEI FILTRI E COLLEGAMENTO IN SERIE 

3.5 LA SINTESI SOTTRATTIVA 

3.6 L'EQUAZIONE DEI FILTRI DIGITALI 

3.7 FILTRI COLLEGATI IN PARALLELO ED EQUALIZZATORI GRAFICI 

3.8 ALTRE APPLICAZIONI DEL COLLEGAMENTO IN SERIE: 
EQUALIZZATORI PARAMETRICI E FILTRI SHELVING 

3.9 ALTRE SORGENTI PER LA SINTESI SOTTRATTIVA: IMPULSI E CORPI 
RISONANTI 
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CONTRATTO FORMATIVO 


PREREQUISITI PER IL CAPITOLO 
e CONTENUTI DEI CAPP. 1 E 2 (TEORIA) 


OBIETTIVI 

CONOSCENZE 

* CONOSCERE LA TEORIA DELLA SINTESI SOTTRATTIVA 

e CONOSCERE LA TEORIA E L'USO DEI PARAMETRI DEI FILTRI PRINCIPALI 

e CONOSCERE LA DIFFERENZA FRA LA TEORIA DEI FILTRI IDEALI E LA RISPOSTA DI QUELLI DIGITALI 

e CONOSCERE LA TEORIA E LA RISPOSTA DEI FILTRI FIR E IIR 

e CONOSCERE L'USO DI FILTRI DISPOSTI IN SERIE O IN PARALLELO 

e CONOSCERE LA TEORIA E L'USO DEGLI EQUALIZZATORI GRAFICI E PARAMETRICI 

® CONOSCERE LE APPLICAZIONI DEI FILTRI A DIVERSI TIPI DI SEGNALE 

e CONOSCERE LE FUNZIONI PRINCIPALI DI UN TIPICO SINTETIZZATORE PER SINTESI SOTTRATTIVA 

ABILITÀ 

* SAPER INDIVIDUARE ALL'ASCOLTO LE CARATTERISTICHE DI BASE DI UN FILTRAGGIO E SAPERLE 
DESCRIVERE 


CONTENUTI 

* SINTESI SOTTRATTIVA 

e FILTRI PASSA-BASSO, PASSA-ALTO, PASSA-BANDA ED ELIMINA-BANDA 

* FILTRI HIGH SHELVING, LOW SHELVING, PEAK/NOTCH 

FATTORE Q 

ORDINI DEI FILTRI 

FILTRI FINITE IMPULSE RESPONSE E INFINITE IMPULSE RESPONSE 

EQUALIZZATORI GRAFICI E PARAMETRICI 

FILTRAGGIO DI SUONI PROVENIENTI DA GENERATORI DI RUMORE, SUONI CAMPIONATI, IMPULSI 


TEMPI - Cap. 3 (TEORIA E PRATICA) + INTERLUDIO B 
AUTODIDATTI 
PER 300 ORE GLOBALI DI STUDIO INDIVIDUALE (VOL. |, TEORIA E PRATICA): 
* CA. 110 ORE 
CORSI 
PER UN CORSO GLOBALE DI 60 ORE IN CLASSE + 120 DI STUDIO INDIVIDUALE 
(voL. |, TEORIA E PRATICA): 
* CA. 18 ORE FRONTALI + 4 DI FEEDBACK 
® CA. 44 DI STUDIO INDIVIDUALE 


ATTIVITÀ 
e ESEMPI INTERATTIVI 


VERIFICHE 
* TEST A RISPOSTE BREVI 
* TEST CON ASCOLTO E ANALISI 


SUSSIDI DIDATTICI 
* CONCETTI DI BASE - GLOSSARIO - DISCOGRAFIA - UN PO' DI STORIA 
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In questo capitolo parleremo dei filtri, argomento fondamentale nel campo del 
sound design e della musica elettronica, e di una tecnica di sintesi che ne fa 
largo uso: la sintesi sottrattiva. 


3.1 SORGENTI PER LA SINTESI SOTTRATTIVA 


La sintesi sottrattiva nasce dall'idea di poter creare un suono modificando, 
attraverso l'uso di filtri, l'ampiezza di alcune componenti di un altro suono. Lo 
scopo della maggior parte dei filtri digitali, infatti, è quello di alterare in qualche 
modo lo spettro di un suono. Un filtro quindi è un dispositivo che agisce preva- 
lentemente su alcune frequenze contenute in un segnale, di solito attenuandole 
o enfatizzandole.! 

Qualsiasi suono può essere filtrato. Attenzione, però! Non possiamo attenuare 
o enfatizzare componenti che non esistono nel suono originario, ad esempio 
non ha senso usare un filtro per enfatizzare i 50 Hz se stiamo filtrando la voce 
di un soprano, semplicemente perché tale frequenza non è presente nel suono 
originario. 

I suoni originari utilizzati in genere nella sintesi sottrattiva sono ricchi dal punto 
di vista spettrale, e, come abbiamo detto, i filtri servono a modellare lo spettro 
di questi suoni e ottenere in uscita suoni diversi da quelli originari. 

In questo paragrafo ci concentreremo sui suoni tipici utilizzati come sorgenti per 
la sintesi sottrattiva e per l'uso dei filtri in genere. Affronteremo le tecniche di 
filtraggio nei paragrafi successivi. 


In generale nel lavoro in studio i filtri vengono utilizzati con diversi tipi di suoni: 


e Suoni provenienti da generatori di rumore, da generatori di impulsi, 
da banchi di oscillatori, da altri generatori di segnale e da algoritmi di 
sintesi 
File audio/suoni campionati 
Suoni provenienti da fonti dal vivo in tempo reale (per esempio un 
suono proveniente dal microfono di un musicista che sta suonando un 
oboe) 


GENERATORI DI RUMORE: RUMORE BIANCO E RUMORE ROSA 


Uno dei suoni più utilizzati come sorgente per la sintesi sottrattiva è il rumore 
bianco, cioè un suono che contiene tutte le frequenze udibili e il cui spettro è 
essenzialmente piatto (pur essendo l'ampiezza delle singole frequenze distri- 
buita casualmente). 


1 Oltre all'ampiezza un filtro può modificare la fase delle componenti di un suono. 
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Ë chiamato rumore bianco 
in analogia con l'ottica, 
dato che il colore bian- 
co contiene tutti i colori 
dello spettro visibile. Si 
utilizza spesso il rumore 
bianco come suono origi- 
nario perché, dal momen- 
to che contiene tutte le 
frequenze udibili, può 
essere utilmente filtrato 


dB 
——— 


i i d kG da qualunque tipo di filtro 
a qualunque frequenza 
fig. 3.1: spettro del rumore bianco (vedi fig. 3.1). 


Un altro tipo di rumore 
spesso utilizzato nella sin- 
tesi sottrattiva è il rumore 
rosa. Quest'ultimo, a dif- 
ferenza del rumore bian- 
co, ha uno spettro la cui 
energia diminuisce all'au- 
mentare della frequenza, 
più precisamente l'atte- 
nuazione è di 3 dB per 


e 109 1000 1000 20000 ottava?; è anche chiamato 
Realta generatore di rumore 1/f, 
fig. 3.2: spettro del rumore rosa per indicare che la sua 


energia spettrale è pro- 
porzionale al reciproco della frequenza. Viene spesso utilizzato, insieme ad 
un analizzatore di spettro, per testare e correggere la risposta in frequenza di 
impianti audio in relazione ad ambienti in cui si svolgono eventi musicali (fig. 
3.2). 


Nei sistemi digitali in genere il rumore bianco viene prodotto mediante gene- 
ratori di numeri random (casuali): l'onda casuale che ne deriva contiene tutte 
le frequenze riproducibili dal sistema digitale usato. In realtà, i generatori di 
numeri random utilizzano procedure matematiche che non sono propriamente 
casuali: infatti generano serie che si ripetono dopo un certo numero di eventi. 
Questi generatori vengono perciò definiti generatori pseudocasuali. 

Modificando alcuni parametri si possono generare tipi di rumore diversi. Il gene- 
ratore di rumore bianco, ad esempio, genera campioni casuali alla frequenza di 


2 Un altro modo per definire la differenza tra rumore bianco e rumore rosa è questo: mentre lo 
spettro del rumore bianco ha la stessa energia per ogni frequenza, lo spettro del rumore rosa ha 
la stessa energia per ogni ottava. Dal momento che salendo verso l'acuto un'ottava occupa uno 
spazio di frequenza doppio dell'ottava precedente, la stessa energia totale viene distribuita in uno 
spazio sempre maggiore e questo determina l'attenuazione di 3 dB caratteristica del rumore rosa. 
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campionamento (ovvero, se la frequenza di campionamento del sistema è 48000 
Hz, vengono generati 48000 valori casuali al secondo); è possibile però modificare 
la frequenza con cui questi numeri vengono generati: utilizzando una frequenza 
di generazione dei numeri pari a 5000 al secondo ad esempio, non avremo più 
un rumore bianco, ma un rumore con forte attenuazione sulle frequenze acute. 


Quando la frequenza di generazione dei campioni è minore della frequenza di 
campionamento si crea il problema di come “riempire i vuoti” tra un campione e 
il successivo: un sistema DSP (vedi glossario cap. 1T) infatti deve sempre produrre 
un numero di campioni al secondo pari alla frequenza di campionamento. Ci sono 
vari modi per risolvere questo problema. In particolare possiamo fare tre esempi: 


e Generatori di campio- 
ni pseudocasuali sem- 
plici. 
Generano valori casuali 
ad una frequenza data 
or e mantengono il valore 
di ciascun campione fino 
pa alla generazione del valo- 
re successivo, creando un 
andamento a gradini. In 
fig. 3.3 vediamo il grafi- 
tempo m co relativo ad un gene- 
fig. 3.3: generazione di valori pseudo-casuali ratore di rumore a 100 
Hz: ogni valore casuale 
generato viene ripetuto nei campioni successivi per un periodo pari ad 
1/100 di secondo, dopo di che si genera un nuovo valore. Se la frequen- 
za di campionamento fosse 48000 Hz, ad esempio, ogni valore casuale 
verrebbe ripetuto per 48000/100 = 480 campioni. 


ampiezza 


* Generatori di campio- 
ni pseudocasuali con 
interpolazione fra un 
numero random e il suc- 
cessivo (vedi la sezione 
sull'interpolazione lineare 
nel cap. 2.1): come pos- 
siamo vedere in fig. 3.4 
i campioni che si trovano 
fra i valori casuali prodot- 
2 805 Di "m "m ti dal generatore formano 
De e un segmento di retta che 
porta gradualmente da 

fig. 3.4 : generazione di valori pseudo-casuali un valore all'altro. 
con interpolazione lineare L'interpolazione tra un 
valore e l'altro puó esse- 
re lineare, come quella 


ampiezza 
o 


«1 
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illustrata in figura, oppu- 
re polinomiale, realizzata 
cioè utilizzando delle fun- 
zioni polinomiali (che non 
approfondiremo in questa 
sede) che collegano i valori 
tramite delle curve anziché 
tramite delle rette (vedi fig. 
3.5). Le interpolazioni polino- 
miali più usate nella compu- 


ampiezza 


o 0.08 m 015 m ter music sono l'interpolazio- 
T ne quadratica (realizzata cioè 
fig. 3.5: generazione di valori pseudo-casuali con un polinomio di secondo 
con interpolazione polinomiale grado) e quella cubica (poli- 


nomio di terzo grado): nor- 
malmente i linguaggi di programmazione per la sintesi e l'elaborazione del suono 
hanno già degli algoritmi pronti che realizzano queste interpolazioni. 


e Generatori di campioni pseudocasuali con filtro: in questo tipo di siste- 
ma il segnale in uscita viene filtrato mediante un filtro passa-basso. Parleremo 
di questo tipo di generatore nella sezione dedicata ai filtri passa-basso. 


OSCILLATORI E ALTRI GENERATORI DI SEGNALE 


Nel paragrafo 1.2 abbiamo visto alcune forme d'onda "classiche" impiegate 
normalmente nei sintetizzatori, come l'onda quadra, l'onda a dente di sega e 
la triangolare; nel paragrafo 2.1, inoltre, abbiamo visto che tali forme d'onda, 
quando sono geometricamente perfette (cioé perfettamente quadrate, triango- 
lari etc.) contengono un numero infinito di componenti. La presenza di infinite 
componenti, peró, causa alcuni importanti problemi nella riproduzione del 
suono digitale: ciò è dovuto al fatto che una scheda audio non può riprodurre 
frequenze superiori alla metà della frequenza di campionamento? (approfondi- 
remo questo argomento nel capitolo 5). 

Quando si tenta di riprodurre digitalmente un suono in cui la frequenza delle 
componenti supera le capacità della scheda, si ottengono componenti indesidera- 
te quasi sempre inarmoniche. Per evitare questo problema vengono spesso usati, 
nella musica digitale, gli oscillatori limitati in banda. Tali oscillatori, che riprodu- 
cono le forme d'onda classiche, sono fatti in modo che le componenti non supe- 
rino mai la metà della frequenza di campionamento. | suoni generati da questo 


3E per questo motivo che la frequenza di una scheda audio ë quasi sempre superiore al doppio 
della massima frequenza udibile dall'uomo. 
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tipo di oscillatori possono quindi essere un buon punto di partenza per ottenere 
sonorità particolari mediante l'uso di filtri, e sono largamente impiegati, infatti, 
nell'implementazione di sintetizzatori che operano mediante la sintesi sottrattiva. 
Nel par. 3.5 analizzeremo la struttura di un tipico sintetizzatore sottrattivo. 
Naturalmente sarà possibile utilizzare per la sintesi sottrattiva anche suoni sintetici 
ricchi di parziali realizzati con le diverse tecniche (ad esempio le tecniche di sintesi 
non lineare o la sintesi per modelli fisici) di cui parleremo nei prossimi capitoli. 


FILTRAGGIO DI SUONI CAMPIONATI 


Uno degli utilizzi più comuni dei filtri e degli equalizzatori, al là della sintesi sot- 
trattiva, è il filtraggio dei suoni campionati. A differenza del rumore bianco, che 
contiene tutte le frequenze alla stessa ampiezza, un suono campionato conterrà 
un numero limitato di frequenze e rapporti d'ampiezza fra le componenti che 
possono variare a seconda del suono considerato. 

È necessario perciò, prima di effettuare un filtraggio, essere coscienti del range 
frequenziale del suono da elaborare. Infatti, come già accennato in precedenza, 
possiamo attenuare o esaltare solo frequenze che siano già contenute nel file di 
partenza. Ciò vale anche per i suoni che giungono al nostro computer da una 
fonte dal vivo. 


(...) 
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II capitolo prosegue con: 


3.2 FILTRI PASSA-BASSO, PASSA-ALTO, PASSA-BANDA ED ELIMINA- 
BANDA 

Filtro passa-basso 

Filtro passa-alto 

Filtro passa-banda 

Filtro elimina-banda 


3.3 IL FATTORE Q O FATTORE DI RISONANZA 


3.4 GLI ORDINI DEI FILTRI E COLLEGAMENTO IN SERIE 
Filtri del primo ordine 
Filtri del secondo ordine 
Filtri del secondo ordine risonanti 
Filtri di ordine superiore: il collegamento in serie 


3.5 LA SINTESI SOTTRATTIVA 
Anatomia di un sintetizzatore in sintesi sottrattiva 


3.6 L'EQUAZIONE DEI FILTRI DIGITALI 
Il filtro non ricorsivo o filtro fir 
Il filtro ricorsivo o filtro iir 


3.7 FILTRI COLLEGATI IN PARALLELO ED EQUALIZZATORI GRAFICI 
Equalizzatore grafico 


3.8 ALTRE APPLICAZIONI DEL COLLEGAMENTO IN SERIE: 
EQUALIZZATORI PARAMETRICI E FILTRI SHELVING 
Filtri shelving 
Equalizzatore parametrico 


3.9 ALTRE SORGENTI PER LA SINTESI SOTTRATTIVA: 
IMPULSI E CORPI RISONANTI 
Analisi del comportamento di un filtro: 
risposta all'impulso e risposta in frequenza 


ATTIVITÀ 
e Esempi interattivi 


VERIFICHE 
e Test a risposte brevi 
e Test con ascolto e analisi 


SUSSIDI DIDATTICI 
e Concetti di base - Glossario - Discografia - Un po' di storia 
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GENERATORI DI RUMORE, FILTRI E 
SINTESI SOTTRATTIVA 


3.1 SORGENTI PER LA SINTESI SOTTRATTIVA 

3.2 FILTRI PASSA-BASSO, PASSA-ALTO, PASSABANDA ED 
ELIMINA-BANDA 

3.3 IL FATTORE Q O FATTORE DI RISONANZA 

3.4 GLI ORDINI DEI FILTRI E COLLEGAMENTO IN SERIE 

3.5 LA SINTESI SOTTRATTIVA 

3.6 L'EQUAZIONE DEI FILTRI DIGITALI 

3.7 FILTRI COLLEGATI IN PARALLELO ED EQUALIZZATORI GRAFICI 

3.8 ALTRE APPLICAZIONI DEL COLLEGAMENTO IN SERIE: FILTRI 
SHELVING ED EQUALIZZATORI PARAMETRICI 

3.9 ALTRE SORGENTI PER LA SINTESI SOTTRATTIVA: IMPULSI E 
CORPI RISONANTI 
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CONTRATTO FORMATIVO 


PREREQUISITI PER IL CAPITOLO 
* CONTENUTI DEI CAPP. 1 E 2 (TEORIA E PRATICA), CAP.3 (TEORIA), INTERLUDIO A 


OBIETTIVI 

ABILITÀ 

* SAPER GENERARE E CONTROLLARE DIVERSI TIPI DI SEGNALI COMPLESSI PER LA SINTESI SOTTRAT- 

TIVA (RUMORE BIANCO, RUMORE ROSA, IMPULSI ETC.) 

* SAPER COSTRUIRE ALGORITMI CON FILTRI PASSA-BASSO, PASSA-ALTO, PASSA-BANDA, ELIMINA- 
BANDA, FILTRI SHELVING E FILTRI RISONANTI, E CONTROLLARNE, FRA | VARI PARAMETRI, ANCHE 
IL Q E L'ORDINE DEI FILTRI. 

e SAPER COSTRUIRE FILTRI FIR O NON RICORSIVI E FILTRI IIR O RICORSIVI 

* SAPER COSTRUIRE SEMPLICI SINTETIZZATORI IN SINTESI SOTTRATTIVA 

* SAPER SCRIVERE ALGORITMI CON COLLEGAMENTI IN SERIE E IN PARALLELO DEI FILTRI 

* SAPER COSTRUIRE EQUALIZZATORI GRAFICI E PARAMETRICI 

COMPETENZE 

* SAPER ANALIZZARE UN BREVE STUDIO SONORO BASATO SULLE TECNICHE DI SINTESI SOTTRATTIVA 
E MEMORIZZARLO SU FILE AUDIO. 


CONTENUTI 

* SORGENTI PER LA SINTESI SOTTRATTIVA 

* FILTRI PASSA-BASSO, PASSA-ALTO, PASSA-BANDA, ELIMINA-BANDA, FILTRI SHELVING E FILTRI RISONANTI 
* IL QUALITY FACTOR E L'ORDINE DEI FILTRI 

FILTRI FIR E IIR 

IL COLLEGAMENTO IN SERIE E IN PARALLELO DEI FILTRI 

GLI EQUALIZZATORI GRAFICI E PARAMETRICI 


TEMPI - CAP. 3 (TEORIA E PRATICA) + INTERLUDIO B 
AUTODIDATTI 
PER 300 ORE GLOBALI DI STUDIO INDIVIDUALE (VOL. |, TEORIA E PRATICA): 
* CA. 110 ORE 
Consi 
PER UN CORSO GLOBALE DI 60 ORE IN CLASSE + 120 DI STUDIO INDIVIDUALE 
(VOL. |, TEORIA E PRATICA): 
* CA. 18 ORE FRONTALI + 4 DI FEEDBACK 
* CA. 44 DI STUDIO INDIVIDUALE 


ATTIVITÀ 
* ATTIVITÀ AL COMPUTER: SOSTITUZIONE DI PARTI DI ALGORITMI, CORREZIONE, COMPLETAMENTO 
E ANALISI DI ALGORITMI, COSTRUZIONE DI NUOVI ALGORITMI 


VERIFICHE 
* REALIZZAZIONE DI UNO STUDIO BREVE - COMPITI UNITARI DI REVERSE ENGINEERING 


SUSSIDI DIDATTICI 
* LISTA OGGETTI NATIVI PD - LISTA OGGETTI DELLA LIBRERIA VIRTUAL SOUND - LISTA MESSAGGI 
PER OGGETTI SPECIFICI - GLOSSARIO 
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3.1 SORGENTI PER LA SINTESI SOTTRATTIVA 


Come sappiamo dal paragrafo 3.1 della teoria, lo scopo di un filtro ë gene- 
ralmente quello di modificare in qualche modo lo spettro di un segnale. 
Introduciamo quindi per prima cosa un oggetto della libreria Virtual Sound che 
ci serve per visualizzare lo spettro: [vs . spectroscope- ]. Per creare l'ogget- 
to è sufficiente scriverne il nome all'interno di un object box generico. 


[x]on/oss (Ojeonsis 


$0-spectrum 


fig. 3.1: l'oggetto [vs. spectroscope-] 
Aprite ora il file 03 01 spectroscope.pd (fig. 3.2). 


Seleziona uno 
dei tre oscillatori 


[x]en/est ets 


$0-spectrum 


fig. 3.2: file 03, 01, spectroscope.pd 
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Qui abbiamo collegato allo spettroscopio un oggetto [vs.sel3-] che ci per- 
mette di "smistare" tre oscillatori con forma d'onda sinusoidale ([osc- ]), a 
dente di sega non limitata in banda ([phasor- ]) e a dente di sega limitata in 
banda ([vs.blsaw-])!. All'ingresso di sinistra di [vs .se13~] sono collegati 
tre message box che servono a selezionare uno dei tre oscillatori: impostando 
la frequenza nel number box e selezionando i tre oscillatori possiamo vedere gli 
spettri relativi. Notate che la sinusoide contiene una sola componente, mentre 
all'oggetto [phasor- ], che genera una forma d'onda non limitata in banda, 
corrisponde lo spettro più ricco?. 


Fate alcune prove, cambiando la frequenza e selezionando le diverse forme 
d'onda e osservate le immagini che si producono nello spettroscopio. Come 
abbiamo detto quello che viene visualizzato è lo spettro del suono in ingresso: 
le diverse componenti del suono sono distribuite da sinistra a destra e vengono 
visualizzate le frequenze da 0 Hz a 22050 Hz. 


Provate ad aggiungere l'oggetto [vs.spectroscope-] alle patch che avete 
già realizzato, in modo da familiarizzarvi con la relazione che c'è tra un suono 
e il suo contenuto spettrale: potete aggiungere l'oggetto anche alle patch dei 
capitoli precedenti, provate ad esempio con 01_13_audiofile.pd (collegando 
lo spettroscopio all'uscita di sinistra dell'oggetto [vs.splayer-] oppure con 
IA_06_random_walk.pd (collegandolo all'uscita di [pd monosynth]) in 
quest'ultima patch riuscite a cogliere la relazione tra la frequenza del suono e 
la forma dello spettro? 


Passiamo adesso al rumore bianco, che viene generato in Pd dall'oggetto 
[noise-] (vedi fig. 3.3). 


X]on/of£ err 


$0-spectrum 


fig. 3.3: generatore di rumore bianco 


1 vedi paragrafo 1.2 
2 L'oggetto [vs. spectroscope-] contiene un algoritmo di analisi spettrale denominato Fast 
Fourier Transform, sui cui torneremo con maggiori dettagli in un capitolo successivo 
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Nella patch dell'immagine (che vi invitiamo a ricostruire) abbiamo collegato 
il generatore di rumore all'oggetto [vs.spectroscope-] tramite il quale 
possiamo vedere che lo spettro del rumore bianco contiene energia a tutte le 
frequenze. A differenza degli altri generatori di suono che abbiamo incontrato 
finora, il generatore di rumore bianco non ha bisogno di alcun parametro: la 
sua funzione infatti è quella di generare un segnale costituito da valori casuali 
compresi tra -1 e 1 alla frequenza di campionamento (vedi par. 3.1 della teoria). 
Un altro tipo di generatore di rumore che abbiamo a disposizione nella libreria 
Virtual Sound è l'oggetto [vs.pink-] che genera rumore rosa (fig. 3.4). 


on/off Oconfig 


$0-spectrum 


fig. 3.4: rumore rosa 


Notate che, a differenza del rumore bianco, lo spettro del rumore rosa subisce 
un'attenuazione man mano che si procede verso le frequenze più alte e l'attenua- 
zione (come sappiamo dal par. 3.1 della teoria) é di 3 dB per ottava. Ricostruite la 
patch e ascoltate bene la differenza tra il rumore rosa e il rumore bianco: quale 
dei due suoni vi sembra piü gradevole (o meno sgradevole) e perché? 
Aggiungete alle due patch appena realizzate un oscilloscopio ([vs.scope-]) 
e osservate le differenze tra la forma d'onda del rumore bianco e quella del 
rumore rosa. In fig. 3.5 vediamo le due forme d'onda affiancate. 


$0-scope $0-scope 


w 


rumore bianco rumore rosa 


fig. 3.5: forma d'onda del rumore bianco e del rumore rosa 


Estratto da “Pure Data: Musica Elettronica e Sound Design” di F. Bianchi, A. Cipriani e M. Giri 
© 2016 ConTempoNet- Tutti i diritti riservati 


336 Pratica - Paragrafo 3.1 - Sorgenti per la sintesi sottrattiva 


Senza entrare nei dettagli tecnici possiamo osservare che mentre il rumore 
bianco ë, come sappiamo, una successione di valori casuali, il rumore rosa viene 
generato con un algoritmo piü complesso, in cui un campione, che ë sempre 
“casuale”, non può però discostarsi eccessivamente dal precedente, e questo 
genera l'andamento "serpeggiante" della forma d'onda che vediamo in figura. 
Il comportamento delle due forme d'onda corrisponde al loro contenuto spet- 
trale: maggiore infatti è la differenza tra un campione e il successivo e maggiore 
è l'energia alle frequenze più alte3, e come abbiamo detto il rumore bianco ha 
maggiore energia alle frequenze alte rispetto al rumore rosa. 


Un altro generatore interessante è [vs .rand1-]4, che genera campioni 
casuali ad una frequenza regolabile a piacere e li collega tramite linee, o meglio 
segmenti di retta (fig. 3.6). A differenza di [noise-] e [vs.pink-], che 
generano un nuovo campione casuale ad ogni ciclo del “motore” DSP (cioè 
generano ogni secondo un numero di campioni casuali pari alla frequenza di 
campionamento, ad es. 44100), con [vs.rand1-] è possibile stabilire la fre- 
quenza con cui i campioni casuali verranno generati, e il passaggio tra un cam- 
pione e il successivo avviene gradualmente, tramite un'interpolazione lineare. 


fig. 3.6: l'oggetto [vs.rand1-] 


Questo generatore produce uno spettro che varia, come è ovvio, in relazione 
alla frequenza impostata, e che presenta una banda di frequenza principale 
che va da 0 Hz alla frequenza impostata, seguita da bande secondarie pro- 
gressivamente attenuate la cui larghezza è pari alla frequenza impostata, vedi 
fig. 3.7. 


3 Per comprendere questa affermazione osserviamo che la forma d'onda di un suono acuto 
oscilla velocemente, mentre quella di un suono grave oscilla lentamente. Nel primo caso, a parità 
di ampiezza, la differenza di valore tra due campioni successivi è mediamente maggiore che nel 
secondo caso. 

41 prefisso vs indica che l'oggetto fa parte della libreria Virtual Sound, come tutti gli altri oggetti 
preceduti da questo prefisso. 
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Kon/ors Ojeonzio 


$0-spectrum 


fig. 3.7: spettro generato dall'oggetto [vs.rand1-] 


Nell'esempio vediamo che la frequenza di [vs .rand1-] ë di 5512.5 Hz (un 
quarto della massima frequenza visualizzabile nello spettroscopio in figura), e la 
prima banda va da 0 Hz a 5512.5 Hz. A questa seguono tre bande secondarie, 
progressivamente attenuate, tutte larghe 5512.5 Hz. Variando la frequenza di 
[vs.randl-] si varia la larghezza delle bande e il loro numero: ad esempio 
se raddoppiamo la frequenza e la portiamo a 11025 Hz otteniamo due bande 
larghe appunto 11025 Hz. 


Un altro generatore di rumore ë [vs.rand0-] (l'ultimo carattere prima della 
tilde ë uno zero) che genera campioni casuali ad una frequenza data come 
[vs.rand1-], ma non effettua alcuna interpolazione e mantiene il valore di 
ciascun campione fino alla generazione del campione successivo, creando un 
andamento a gradini. 


Lo spettro è diviso in bande come lo spettro di [vs. rand1-] in fig. 3.7, ma 
l'attenuazione delle bande secondarie ë molto minore a causa del brusco pas- 
saggio fra un campione e il successivo (vedi fig. 3.8). 


on/off Ojeontio 


$0-spectrum 


fig. 3.8: l'oggetto [vs .rand0-] 


Estratto da "Pure Data: Musica Elettronica e Sound Design" di F. Bianchi, A. Cipriani e M. Giri 
@ 2016 ConTempoNet- Tutti i diritti riservati 


338 Pratica - Paragrafo 3.1 - Sorgenti per la sintesi sottrattiva 


Nella libreria Virtual Sound abbiamo anche un generatore di rumore con inter- 
polazione polinomiale [vs .rand3-] (vedi fig. 3.9). 


Kon/oss er 


$0-spectrum 


fig. 3.9: l'oggetto [vs.rand3-] 


Come si vede nell'oscilloscopio, grazie all'interpolazione polinomiale il passag- 
gio tra un campione e l'altro appare “smussato”, essendo costituito non da 
una linea retta ma da una curva: l'effetto è una forte attenuazione delle bande 
secondarie. Ricreate le patch delle figure 3.6/3.9 per sperimentare i diversi 
generatori di rumore. 

Altre sorgenti ricche di componenti con le quali si possono utilizzare efficace- 
mente i filtri sono gli oscillatori “classici”, con forma d'onda a dente di sega, 
quadrata e triangolare. Nel paragrafo 1.2 abbiamo visto i tre oscillatori limitati in 
banda che generano queste forme d'onda: [vs.blsaw-], [vs.blsquare-] 
e [vs.bltri-]. Utilizzeremo questi oscillatori nel corso di questo capitolo. 


Nel paragrafo 3.1 della parte teorica abbiamo anche accennato alla possibilità 
di filtrare i suoni campionati: daremo perciò nel corso del capitolo, degli esempi 
di filtraggio di suoni campionati utilizzando l'oggetto [vs.splayer-] (di cui 
abbiamo parlato nel par. 1.5). 


(a) 
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II capitolo prosegue con: 
3.2 FILTRIPASSA-BASSO, PASSA-ALTO, PASSA-BANDA ED ELIMINA-BANDA 
3.3 IL FATTORE Q O FATTORE DI RISONANZA 


3.4 GLI ORDINI DEI FILTRI E COLLEGAMENTO IN SERIE 
Filtri del primo ordine 
Filtri del secondo ordine 
Filtri di ordine superiore: il collegamento in serie 


3.5 LA SINTESI SOTTRATTIVA 
Il simbolo $0 e l'oggetto value 
Scelta multipla: l'oggetto vradio 
Anatomia di un sintetizzatore in sintesi sottrattiva 


3.6 L'EQUAZIONE DEI FILTRI DIGITALI 
Il filtro non ricorsivo o filtro fir 
Il filtro ricorsivo o filtro iir 


3.7 FILTRI COLLEGATI IN PARALLELO ED EQUALIZZATORI GRAFICI 
Utilizzare un banco di filtri paralleli 
Equalizzatore grafico 


3.8 ALTRE APPLICAZIONI DEL COLLEGAMENTO IN SERIE: 
EQUALIZZATORI PARAMETRICI E FILTRI SHELVING 
Equalizzatore parametrico 


3.9 ALTRE SORGENTI PER LA SINTESI SOTTRATTIVA 
IMPULSI E CORPI RISONANTI 


ATTIVITÀ 
* Sostituzione di parti di algoritmi, correzione di algoritmi, completamento di 
algoritmi 


VERIFICHE 
* Compiti unitari di reverse engineering, Realizzazione di uno studio breve 


SUSSIDI DIDATTICI 
e Lista oggetti nativi Pd - Lista oggetti della libreria Virtual Sound - Lista mes- 
saggi per oggetti specifici 
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ALTRI ELEMENTI DI PROGRAMIMAZIONE 
CON PURE DATA 


IB.1 CENNI SUL MIDI 

IB.2 L'OPERATORE MODULO E LA RICORSIONE 

IB.3 SMISTARE SEGNALI E MESSAGGI 

IB.4 GLI OPERATORI RELAZIONALI E L'OGGETTO SELECT 

IB.5 L'OGGETTO MOSES 

IB.6 SCOMPORRE UNA LISTA, L'OGGETTO ITER 

IB.7 LOOP DI DATI 

IB.8 GENERARE UNA LISTA RANDOM 

IB.9 CALCOLI E CONVERSIONI CON PURE DATA 

IB.10 UTILIZZO DI ARRAY PER GLI INVILUPPI: LO SHEPARD TONE 
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CONTRATTO FORMATIVO 


PREREQUISITI PER IL CAPITOLO 
e CONTENUTI DEI CAPP. 1, 2 E 3 (TEORIA E PRATICA), INTERLUDIO A 


OBIETTIVI 

ABILITÀ 

* SAPER UTILIZZARE DIVERSI OGGETTI E SEGNALI MIDI SEMPLICI 

* SAPER UTILIZZARE OPERAZIONI RICORSIVE E CONVERSIONI IN PD 

* SAPER COSTRUIRE UN ARPEGGIATORE, ANCHE CON USO DI INTERVALLI PROBABILISTICI 
* SAPER SMISTARE SEGNALI E MESSAGGI SELEZIONANDO INGRESSI E USCITE 

* SAPER CONFRONTARE VALORI E ANALIZZARNE LA RELAZIONE 

e SAPER SCOMPORRE LISTE DI DATI 

* SAPER COSTRUIRE SEQUENZE RIPETITIVE, TRAMITE LOOP DI DATI 

e SAPER GENERARE LISTE CASUALI PER LA SIMULAZIONE DI CORPI RISONANTI 
* SAPER COSTRUIRE UNO SHEPARD TONE, O GLISSANDO INFINITO 


CONTENUTI 

* USO DI BASE DEL PROTOCOLLO MIDI 

* OPERAZIONI RICORSIVE E SEQUENZE RIPETITIVE 

* ARPEGGIATORI E INTERVALLI PROBABILISTICI 

* CONFRONTO DI VALORI, CONVERSIONI E SMISTAMENTO DI SEGNALI E MESSAGGI 
® SCOMPOSIZIONE DI LISTE E GENERAZIONE DI LISTE CASUALI 

* SHEPARD TONE 


TEMPI - CAP.3 (TEORIA E PRATICA) + INTERLUDIO B 
AUTODIDATTI 
PER 300 ORE GLOBALI DI STUDIO INDIVIDUALE (VOL. |, TEORIA E PRATICA): 
* CA. 110 ORE 
CORSI 
PER UN CORSO GLOBALE DI 60 ORE IN CLASSE + 120 DI STUDIO INDIVIDUALE 
(VOL. |, TEORIA E PRATICA): 
® CA. 18 ORE FRONTALI + 4 DI FEEDBACK 
® CA. 44 DI STUDIO INDIVIDUALE 


ATTIVITÀ 

ATTIVITÀ AL COMPUTER: 

® SOSTITUZIONE DI PARTI DI ALGORITMI, CORREZIONE, COMPLETAMENTO E ANALISI DI ALGORITMI, 
COSTRUZIONE DI NUOVI ALGORITMI 


VERIFICHE 
e COMPITI UNITARI DI REVERSE ENGINEERING 


SUSSIDI DIDATTICI 
* LISTA OGGETTI NATIVI DI PD - LISTA OGGETTI DELLA LIBRERIA VIRTUAL SOUND - GLOSSARIO 
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IB.1 CENNI SUL MIDI 


II MIDI ë un sistema di comunicazione tra computer e strumenti musicali elet- 
tronici e/o digitali: tramite questo sistema ë possibile, ad esempio, collegare 
(con un apposito cavetto MIDI) un computer ad un sintetizzatore e far si che 
quest'ultimo venga “suonato” dal computer. In altre parole grazie al MIDI il 
computer può dire al sintetizzatore, tra le altre cose, quali note suonare, con 
che intensità, con che durata etc. 

Gli strumenti musicali digitali, inoltre, possono anche essere “virtuali”, cioè 
possono essere delle applicazioni residenti nel nostro computer che simulano 
il comportamento di strumenti digitali reali: anche con gli strumenti virtuali è 
possibile comunicare via MIDI, realizzando una connessione, in questo caso 
virtuale (cioè non con un cavo fisico), tra il programma che invia i comandi MIDI 
(ad esempio Pd) e il programma (lo strumento virtuale) che li riceve. 

Come vedremo successivamente in modo più approfondito, Pd ha diversi ogget- 
ti che sfruttano il protocollo MIDI e dal momento che nel seguito di questo 
Interludio ne verranno utilizzati alcuni, è bene configurare adeguatamente il 
vostro sistema affinché Pd possa comunicare con i dispositivi MIDI presenti nel 
computer. Per una trattazione più dettagliata di questo argomento potete sca- 
ricare il documento pdf relativo (MESD MIDI config.pdf). In linea di massima 
per collegare Pd ad un dispositivo MIDI virtuale su un sistema Windows e suffi- 
ciente aprire Pd, e dal menu Media/MIDI Settings impostare in corrispondenza 
dell'uscita Output Device 1 la voce Microsoft GS Wavetable!. 


Su Mac invece: 


1. aprite la finestra di configurazione MIDI Audio (accessibile nella cartella 
/Application/Utility o dal Launchpad) e verificate che il driver IAC sia attivo; 

2. aprite Pd e dal menu Media/MIDI settings selezionate /AC Driver dal menu 
Output Device 1; 

3. aprite un software che possa ospitare strumenti virtuali (Garageband o simili). 


Una volta configurato il MIDI aprite il file IB 01 note MIDI.pd; in fig. IB.1 
vediamo la parte superiore della patch. 


W| mono clear 

ZI 

poly [O 
touch 

48 | bkey 


64 | bve1 


nota MIDI velocity 


fig. IB.1: file IB. 01. note MIDI.pd, parte superiore 


1 La denominazione potrebbe cambiare fra versioni diverse del sistema Windows, ma non vi 
spaventate, riconoscerete comunque il dispositivo! 
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Abbiamo collegato l'oggetto [vs .midikeyboard] (la tastiera musicale) a dei 
number box e, tramite questi, all'oggetto [noteout ]. Come possiamo vedere, 
facendo clic su un tasto di [vs.midikeyboard] avremo all'uscita di sinistra 
il valore MIDI della nota selezionata (cfr. anche il par. 1.4) e all'uscita di destra il 
valore di velocity, ovvero l'intensità della nota: facendo clic nella parte alta di un 
tasto di [vs.midikeyboard] si ottengono valori alti di velocity, facendo clic 
sulla parte bassa si ottengono valori bassi. La velocity può variare tra 1 e 127. 
| valori di nota MIDI e velocity vengono inviati agli ingressi di sinistra e centrale 
dell'oggetto [noteout ]: quest'ultimo invia il comando relativo all'esecuzione 
della nota allo strumento (reale o virtuale) a cui ë collegato.2 


Nel protocollo MIDI questo comando si definisce note-on. Se fate clic su un 
tasto del [vs.midikeyboard] (abbastanza in alto in modo da ottenere una 
velocity alta, superiore a 90) e se avete configurato il MIDI in modo corretto, 
dovreste sentire un suono di pianoforte3. Questo suono non proviene da Pd, 
ma dallo strumento virtuale contenuto nel vostro computer che solitamente ë 
impostato sul suono del pianoforte. Se provate a suonare piü note vi accorge- 
rete che, per ogni coppia nota-velocity che l'oggetto [noteout ] riceve, viene 
suonata una nuova nota, ma le precedenti non vengono interrotte: ë come 
se i tasti fossero “incantati”. Il problema è che, tramite [noteout], stiamo 
dicendo allo strumento virtuale quando iniziare a suonare una nota, ma non gli 
diciamo quando interromperla! 

Per interrompere una nota dobbiamo inviare nuovamente il valore MIDI relativo 
associato ad una velocity pari a 0. Il valore di velocity 0 corrisponde al comando 
note-off, ovvero “solleva il dito dal tasto”. 

Per poter “spegnere” una nota MIDI tramite il [vs.midikeyboard] dob- 
biamo cambiare il modo con cui quest'ultimo gestisce i messaggi di nota MIDI: 
nella parte destra dell'oggetto selezionate il modo denominato poly (prima 
eravate in modalità mono). 

Adesso la prima volta che fate clic su un tasto del [vs . mi dikeyboard] verrà 
suonata una nota con la velocity corrispondente, un secondo clic sullo stesso 
tasto invierà nuovamente la nota, ma con velocity pari a 0, facendo termina- 
re il suono: provate! Questo modo ë definito poly, cioé polifonico perché, a 
differenza del mono, cioè monofonico, ci permette di tenere attive più note 
contemporaneamente. 

In figura IB.2 vediamo la parte inferiore del file IB 01 note MIDI.pd. 


Qui abbiamo collegato l'oggetto [vs.midikeyboard] (in modalità mono) 
all'oggetto [makenote]: quest'ultimo ogni volta che riceve un comando MIDI 
note-on genera il corrispondente comando MIDI note-off dopo un intervallo di 
tempo stabilito. L'oggetto ha tre ingressi, rispettivamente per il valore di nota 
MIDI, la velocity e la durata in millisecondi (ovvero il tempo che deve passare tra 


2 L'ingresso di destra dell'oggetto [noteout ] serve per impostare il canale MIDI, che al momento 
non ci serve: maggiori dettagli verranno successivamente. 

3 Se non sentite niente significa che non avete configurato correttamente il sistema e quindi dovete 
tornare all'inizio del capitolo oppure consultare il pdf MESD MIDI config.pdf, che potete scaricare 
dalle pagine di supporto per questo testo. 
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un note-on e il successivo note-off), e due uscite, per il valore di nota MIDI e la 


velocity. 
W| mono clear 
Hes 
touch 
48 | bkey 
[64 ) bve1 


durata 


nota MIDI velocity 


makenote 1 50 


f 


ig. IB.2: file IB. 01 note MIDI.pd, parte inferiore 


Gli argomenti sono due: la velocity e la durata in millisecondi; nella patch 
abbiamo quindi una velocity pari a 1 e una durata di 500 millisecondi (mezzo 
secondo). Quando l'oggetto riceve un note-on lo invia direttamente alle usci- 
te, dopo di che attende la durata prescritta (nel nostro caso 500 millisecondi) 
dopo di che invia il note-off. Notate che la velocity che inviamo tramite il [vs. 
midikeyboard] (nel caso in figura il valore 81) annulla e sostituisce il valore 
1 che avevamo scritto come argomento: quest'ultimo ci ë servito infatti solo 
per permetterci di scrivere il secondo argomento, cioé la durata, che in quanto 
"secondo argomento" deve essere per forza preceduto dal primo! 

Anche la durata puó essere modificata, inviando il nuovo valore all'ingresso di 
destra, che sostituirà il valore che abbiamo messo come secondo argomento. 
Provate a suonare alcune note e a cambiare la durata nell'oggetto [makeno- 
te]: osservate come dalla sua seconda uscita venga generato prima un valore 
di velocity identico a quello generato dal [vs.midikeyboard] e, dopo il 
tempo stabilito, il valore O. 

Ora aggiungiamo un sommatore alla parte inferiore della patch nel modo illu- 
strato in fig. IB.3. 


velocity 


note MIDI 


fig. IB.3: trasposizione MIDI 
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Questa patch è simile a quella del file IA_01_trasposizione.pd che abbiamo 
visto al primo paragrafo dell'interludio A. Anche in questo caso per ogni tasto 
premuto nell'oggetto [vs.midikeyboard] vengono generate due note a 
distanza di 7 semitoni, cioè di una quinta. Ogni volta che facciamo clic su un 
tasto di [vs. midikeyboard], infatti, il valore di nota MIDI corrispondente 
viene inviato all'oggetto [makenote] e contemporaneamente ad un somma- 
tore che aggiunge il valore 7 alla nota prima di inviarla a sua volta al [make- 
note]. Notate che per ottenere queste coppie di note non abbiamo avuto 
bisogno di sdoppiare anche il valore della velocity, né quello della durata: questi 
ultimi infatti corrispondono agli ingressi “freddi” dell'oggetto [makenote] 
e aggiornano soltanto le variabili interne dell'oggetto. Il contenuto di queste 
variabili interne viene riutilizzato ogni volta che un nuovo valore arriva all'ingres- 
so “caldo”: nel caso in figura, ad esempio, entrambe le note (DO e SOL centrali) 
hanno una velocity pari a 61 e una durata di 500 millisecondi. 

Qui possiamo vedere che la regola secondo cui l'ingresso "caldo" di un oggetto 
ë quello piü a sinistra ë il logico complemento della regola dell'ordine di esecu- 
zione da destra a sinistra: i primi messaggi ad essere trasmessi sono quelli più 
a destra, che raggiungono gli ingressi "freddi" e aggiornano le variabili interne 
di un oggetto (ad esempio la velocity in [makenote ]), mentre gli ultimi sono 
quelli piü a sinistra, che raggiungono un ingresso "caldo" e provocano un 
output dopo che tutte le variabili interne sono state aggiornate. 


(...) 
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407 


II capitolo prosegue con: 


IB.2 


IB.3 


IB.4 


IB.5 


IB.6 


IB.7 


IB.8 


IB.9 


IB.10 UTILIZZO DI ARRAY PER GLI INVILUPPI: LO SHEPARD TONE 


L'OPERATORE MODULO E LA RICORSIONE 
La ricorsione 
Costruiamo un arpeggiatore 


SMISTARE SEGNALI E MESSAGGI 


GLI OPERATORI RELAZIONALI E L'OGGETTO SELECT 
L'oggetto select 
Un metronomo “probabilistico” 


L'OGGETTO MOSES 

Un metronomo a velocità variabile 
Una semplice catena di Markov 
Un contrappunto più “severo” 


SCOMPORRE UNA LISTA, L'OGGETTO ITER 
Il filtro non ricorsivo o filtro fir 
Il filtro ricorsivo o filtro iir 


LOOP DI DATI 
Utilizzare un banco di filtri paralleli 
Equalizzatore grafico 


GENERARE UNA LISTA RANDOM 
Equalizzatore parametrico 


CALCOLI E CONVERSIONI CON PURE DATA 
L'oggetto expr 
Convertire intervalli di valori e segnali 


L'oggetto tabread4- nel dettaglio 
Uso di array per inviluppi consecutivi 
Lo Shepard tone 


ATTIVITÀ 
e Analisi di algoritmi, completamento di algoritmi, sostituzione di parti di algorit- 
mi, correzione di algoritmi, 


VERIFICHE 
e Compiti unitari di reverse engineering 


SUSSIDI DIDATTICI 
e Lista oggetti nativi Pd - Lista oggetti della libreria Virtual Sound - Glossario 
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4T 


SEGNALI DI CONTROLLO 


4.1 SEGNALI DI CONTROLLO: IL PANNING STEREOFONICO 

4.2 DC OFFSET 

4.3 SEGNALI DI CONTROLLO PER LA FREQUENZA 

4.4 SEGNALI DI CONTROLLO PER L'AMPIEZZA 

4.5 MODULAZIONE DEL DUTY CYCLE (PULSE WIDTH MODULATION) 
4.6 SEGNALI DI CONTROLLO PER I FILTRI 

4.7 ALTRI GENERATORI DI SEGNALI DI CONTROLLO 

4.8 SEGNALI DI CONTROLLO: IL PANNING MULTICANALE 
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CONTRATTO FORMATIVO 


PREREQUISITI PER IL CAPITOLO 
* CONTENUTI DEI CAPP. 1, 2, 3 (TEORIA) 


OBIETTIVI 

CONOSCENZE 

e CONOSCERE LA TEORIA E L'USO DEI PARAMETRI DEGLI OSCILLATORI A BASSA FREQUENZA (LFO) 

e Conoscere L'uso DEL DC OFFSET APPLICATO AGLI LFO 

* CONOSCERE L'USO DELLA MODULAZIONE DI FREQUENZA PER IL VIBRATO 

e CONOSCERE L'USO DELLA MODULAZIONE DI AMPIEZZA PER IL TREMOLO 

* CONOSCERE L'USO DELLA MODULAZIONE DEL DUTY CYCLE (PULSE WiprH MODULATION) 

* CONOSCERE L'uso DEGLI LFO PER GENERARE SEGNALI DI CONTROLLO PER | FILTRI 

e CONOSCERE L'USO DI GENERATORI DI SEGNALI PSEUDOCASUALI COME LFO DI CONTROLLO 

* CONOSCERE L'USO DEGLI OSCILLATORI DI CONTROLLO PER LO SPOSTAMENTO DEL SUONO NEI 
SISTEMI STEREOFONICI E MULTICANALE 

ABILITÀ 

* SAPER INDIVIDUARE ALL'ASCOLTO LE MODIFICHE DEI PARAMETRI BASE DI UN LFO E SAPERLE 
DESCRIVERE 


CONTENUTI 

* OSCILLATORI A BASSA FREQUENZA: DEPTH, RATE E DELAY 

e GESTIONE DEI PARAMETRI DEGLI LFO E uso DEL DC OFFSET 

* GESTIONE DEL VIBRATO, DEL TREMOLO E DEL PWM MEDIANTE GLI LFO 
* GESTIONE DEI PARAMETRI DEI FILTRI MEDIANTE LFO 

* SPOSTAMENTO DEL SUONO NEI SISTEMI STEREO E MULTICANALE 

* OSCILLATORI DI CONTROLLO MODULATI DA ALTRI LFO 


TEMPI - CAP. 4 (TEORIA E PRATICA) 
AUTODIDATTI 
PER 300 ORE GLOBALI DI STUDIO INDIVIDUALE (VOL. |, TEORIA E PRATICA): 
* CA. 30 ORE 
Consi 
PER UN CORSO GLOBALE DI 60 ORE IN CLASSE + 120 DI STUDIO INDIVIDUALE 
(voL. |, TEORIA E PRATICA): 
* CA. 5 ORE FRONTALI + 1 DI FEEDBACK 
* CA. 12 DI STUDIO INDIVIDUALE 


ATTIVITÀ 
* ESEMPI INTERATTIVI 


VERIFICHE 
* TEST A RISPOSTE BREVI 
* TEST CON ASCOLTO E ANALISI 


SUSSIDI DIDATTICI 
* CONCETTI DI BASE - GLOSSARIO 
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4.1 SEGNALI DI CONTROLLO: IL PANNING 
STEREOFONICO 


Come abbiamo visto nel Cap. 1 è possibile variare i parametri di un suono (ad 
esempio la frequenza o l'ampiezza) tramite inviluppi che descrivono l'andamen- 
to nel tempo dei parametri in questione. | segnali (come quelli che controllano 
gli inviluppi), che non servono a generare un suono ma a variarne le caratteri- 
stiche, si definiscono segnali di controllo. Finora abbiamo usato, come segnali 
di controllo, soltanto segmenti di retta o di esponenziale. Questa tecnica si 
rivela efficace quando dobbiamo descrivere il cambiamento di un parametro 
attraverso pochi valori: ad esempio, per un inviluppo ADSR abbiamo bisogno di 
4 segmenti, mentre il glissando di una nota può essere realizzato con una sin- 
gola curva esponenziale. | parametri di un suono possono però variare anche in 
modo più complesso. Pensiamo ad esempio al vibrato di uno strumento ad arco: 
si tratta di un'oscillazione continua della frequenza della nota intorno ad un'al- 
tezza centrale. Per simulare questa vibrazione avremmo bisogno di decine o 
centinaia di segmenti, ma sarebbe evidentemente poco pratico e molto faticoso. 
Possiamo invece utilizzare un oscillatore di controllo, cioè un oscillatore che 
non serve a produrre suoni ma semplicemente valori che variano da un minimo 
a un massimo con una certa velocità e che vengono generalmente assegnati ai 
parametri degli oscillatori audio. Tali valori possono essere assegnati anche a 
parametri di altri algoritmi di sintesi ed elaborazione del suono. 

È importante osservare che gli oscillatori di controllo sono oscillatori in bassa 
frequenza (LFO, Low Frequency Oscillators): essi cioè oscillano con frequen- 
ze generalmente inferiori a 30 Hz, e producono valori di controllo in continuo 
mutamento, che seguono la forma d'onda dell'oscillatore stesso. Ogni ampiezza 
istantanea dell'onda generata dall'oscillatore di controllo corrisponde ad un 
valore numerico che viene poi applicato ai parametri audio che vogliamo. 
Facciamo un esempio: in figura 4.1 vediamo un LFO che controlla la posizione 
del suono nello spazio e genera una sinusoide che oscilla fra MIN (valore mini- 
mo) e MAX (valore massimo). 


mise | valori minimo e massimo si 
riferiscono ai valori dell'ampiez- 
za dell'oscillatore di controllo (di 
solito definita come depth, che 
INT in italiano significa profondità), la 
velocità dell'oscillazione dipende 
invece dalla frequenza dell'oscil- 
latore di controllo (di solito defi- 
i i i i nita come rate, che in italiano 


MIN |- 


nh T Ts T , Nn SE 
significa velocità, o frequenza). 
fig. 4.1: LFO che controlla la | valori delle ampiezze istantanee 
posizione del suono nello spazio della sinusoide generata da un 


LFO (o oscillatore di controllo) 
vengono usati come moltiplicatori delle ampiezze dei due canali in uscita di un 
oscillatore audio: quando la sinusoide dell'oscillatore di controllo raggiungerà 
il valore minimo MIN avremo il suono dell'oscillatore audio completamente a 
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sinistra, quando l'oscillatore di controllo raggiungerà il valore massimo MAX 
avremo il suono dell'oscillatore audio completamente a destra, quando la sinu- 
soide dell'oscillatore di controllo si troverà in corrispondenza del valore interme- 
dio (INT) le ampiezze del suono sul canale sinistro e destro saranno uguali e di 
conseguenza percepiremo il suono al centro. 

É ovviamente possibile anche utilizzare altre forme d'onda (triangolare, casuale 
etc.) per variare questi parametri di controllo; ad esempio, se usiamo un'onda 
quadra lo spostamento da destra a sinistra e viceversa non avverrà in modo con- 
tinuo, come con la sinusoide, ma in modo alternato (MIN-MAX-MIN-MAX etc.). 


Bv EseMPIO INTERATTIVO 4A e Panning mediante LFO con diverse forme 


d'onda 


La velocità (cioé il rate) con cui tali valori oscillano dipende dalla frequenza che 
assegniamo all'oscillatore di controllo. Se utilizzassimo la frequenza 1 avremmo 
un'oscillazione fra MAX e MIN e ritorno una volta al secondo, se applicassimo 
una frequenza pari a .2 avremmo un'oscillazione completa ogni 5 secondi. E se 
utilizzassimo la frequenza 220? L'oscillazione sarebbe troppo veloce per poter 
percepire lo spostamento da destra a sinistra e ritorno (220 volte al secondo!); 
inoltre questa frequenza rientrerebbe nel campo audio e ció aggiungerebbe 
nuove componenti allo spettro del suono risultante, come vedremo nel capitolo 
10 nel paragrafo dedicato alla modulazione di ampiezza. 


gv ESEMPIO INTERATTIVO 4B ° Panning mediante LFO sinusoidale a diverse 


frequenze 


Con gli oscillatori di controllo possiamo, in modi analoghi a quello descritto 
sopra, controllare ampiezza (depth) e velocità (rate) di un vibrato, di un tremolo, 
della variazione dei parametri di un filtro, come vedremo nei prossimi paragrafi. 


(...) 
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Il capitolo prosegue con: 


4.3 SEGNALI DI CONTROLLO PER LA FREQUENZA 
Il vibrato 
Depth del vibrato 
Rate del vibrato 


4.4 SEGNALI DI CONTROLLO PER L'AMPIEZZA 
4.5 MODULAZIONE DEL DUTY CYCLE (PULSE WIDTH MODULATION) 
4.6 SEGNALI DI CONTROLLO PER I FILTRI 


4.7 ALTRI GENERATORI DI SEGNALI DI CONTROLLO 
Controllare un sintetizzatore sottrattivo con un Ifo 


4.8 SEGNALI DI CONTROLLO: IL PANNING MULTICANALE 


ATTIVITÀ 
e Esempi interattivi 


VERIFICHE 
e Test a risposte brevi 
e Test con ascolto e analisi 


SUSSIDI DIDATTICI 
e Concetti di base - Glossario 
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4P 


SEGNALI DI CONTROLLO 


4.1 SEGNALI DI CONTROLLO: IL PANNING STEREOFONICO 

4.2 DC OFFSET 

4.3 SEGNALI DI CONTROLLO PER LA FREQUENZA 

4.4 SEGNALI DI CONTROLLO PER L'AMPIEZZA 

4.5 MODULAZIONE DEL DUTY CYCLE (PULSE WIDTH MODULATION) 
4.6 SEGNALI DI CONTROLLO PER I FILTRI 

4.7 ALTRI GENERATORI DI SEGNALI DI CONTROLLO 

4.8 SEGNALI DI CONTROLLO: IL PANNING MULTICANALE 
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CONTRATTO FORMATIVO 


PREREQUISITI PER IL CAPITOLO 
* CONTENUTI DEI CAPP. 1, 2, 3 (TEORIA E PRATICA), CAP.4 (TEORIA), INTERLUDIO A E B 


OBIETTIVI 

ABILITÀ 

* SAPER FAR OSCILLARE UN SUONO NELLO SPAZIO STEREOFONICO 

* SAPER REALIZZARE EFFETTI DI VIBRATO 

* SAPER SIMULARE STRUMENTI CONTROLLATI IN FREQUENZA, COME IL THEREMIN 

* SAPER REALIZZARE EFFETTI DI TREMOLO 

e SAPER REALIZZARE ALGORITMI DI PULSE WIDTH MODULATION 

* SAPER VARIARE IN MODO OSCILLANTE LA FREQUENZA DI TAGLIO, LA FREQUENZA CENTRALE E IL 
Q DEI FILTRI MEDIANTE SEGNALI DI CONTROLLO 

* SAPER UTILIZZARE SEGNALI DI CONTROLLO PSEUDOCASUALI 

e FAR RUOTARE (TRAMITE UN SEGNALE DI CONTROLLO) IL SUONO A QUATTRO O PIÙ CANALI 

COMPETENZE 

* SAPER REALIZZARE UN BREVE STUDIO SONORO BASATO SULLE TECNICHE DI CONTROLLO DEI 
PARAMETRI MEDIANTE LFO 


CONTENUTI 

® OSCILLATORI A BASSA FREQUENZA: DEPTH, RATE E DELAY 

e GESTIONE DEI PARAMETRI DEGLI LFO E uso peL DC OFFSET 

* GESTIONE DEL VIBRATO, DEL TREMOLO E DEL PWM MEDIANTE GLI LFO 
* GESTIONE DEI PARAMETRI DEI FILTRI MEDIANTE LFO 

* SEGNALI DI CONTROLLO PSEUDOCASUALI 

* SPOSTAMENTO DEL SUONO NEI SISTEMI STEREO E MULTICANALE 


TEMPI - CAP. 4 (TEORIA E PRATICA) 
AUTODIDATTI 
PER 300 ORE GLOBALI DI STUDIO INDIVIDUALE (VOL. |, TEORIA E PRATICA): 
* CA. 30 ORE 
Consi 
PER UN CORSO GLOBALE DI 60 ORE IN CLASSE + 120 DI STUDIO INDIVIDUALE 
(voL. |, TEORIA E PRATICA): 
* CA. 5 ORE FRONTALI + 1 DI FEEDBACK 
* CA. 12 DI STUDIO INDIVIDUALE 


ATTIVITÀ 
* ATTIVITÀ AL COMPUTER: SOSTITUZIONE DI PARTI DI ALGORITMI, CORREZIONE, COMPLETAMENTO 
E ANALISI DI ALGORITMI, COSTRUZIONE DI NUOVI ALGORITMI 


VERIFICHE 
* REALIZZAZIONE DI UNO STUDIO BREVE 
* COMPITI UNITARI DI REVERSE ENGINEERING 


SUSSIDI DIDATTICI 
* LISTA OGGETTI NATIVI DI PD — LISTA OGGETTI DELLA LIBRERIA VIRTUAL SOUND - GLOSSARIO 
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4.1 SEGNALI DI CONTROLLO: IL PANNING STEREOFONICO 


Per far oscillare un segnale nello spazio stereofonico, come descritto nel par. 
4.1 della teoria, possiamo utilizzare, come segnale di controllo sinusoidale, il 
normale oggetto [osc- ], al quale daremo frequenze molto basse, al di sotto 
della minima frequenza udibile. 

Come abbiamo visto nel par. 1.6, si può definire la posizione stereofonica di 
un segnale con un valore n compreso fra zero e uno. La radice quadrata di tale 
valore rappresenta il fattore di moltiplicazione dell'ampiezza di un canale mentre 
la radice quadrata di 1 — n quello per l'altro canale. La patch in figura 4.1, che 
vi invitiamo a riprodurre, mostra l'algoritmo per il controllo della posizione ste- 
reofonica di un segnale costituito da un'onda a dente di sega limitata in banda. 


canale sinistro [*- | canale destro 


fig. 4.1: algoritmo per il panning stereofonico 


Ora è necessario collegare all'inlet dell'oggetto [ expr- ]! e all'inlet di [sqrt- ] 
a destra il segnale generato da [osc- ] per controllare la posizione stereofoni- 
ca. Come sappiamo [osc-] genera una sinusoide con valori compresi fra -1 e 
1, mentre noi abbiamo bisogno di un segnale compreso fra 0 e 1. Si potrebbe 
modificare l'intervallo di oscillazione di [osc- ] con un paio di semplici calcoli, ma 
questo lo vedremo nel prossimo paragrafo; qui preferiamo usare un oggetto di cui 
abbiamo già parlato nell'Interludio IB.9. Completate la patch come da figura 4.2. 


segnale che oscilla fra -l e 1 


vs.kscale- -1 1 0 1 


segnale riscalato fra 0 e 1 


canale sinistro 


fig. 4.2: panning stereofonico controllato da un LFO 


1 Ricordiamo che l'oggetto [expr-] è l'omologo per il segnale di [expr]. Le variabili per il 
segnale iniziano sempre con il prefisso '$v' seguito dal numero della variabile. L'in/et di sinistra deve 
sempre essere di tipo segnale, quindi la prima variabile sarà sempre '$v1' mentre le altre variabili 
(quindi gli altri inlet) possono anche essere di tipo 'f' o “T. 
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L'oggetto [vs.kscale-], come sappiamo, ha quattro argomenti, i primi due 
specificano l'intervallo di entrata e gli ultimi due l'intervallo di uscita. Nel nostro 
caso, gli argomenti [-1 1 0 1] indicano che se mandiamo a [vs.kscale-] un 
segnale che varia fra -1 e 1 avremo in uscita un segnale riscalato che varia fra 
0 e 1, che è esattamente quello che ci serve. L'oggetto [osc-] genera una 
sinusoide di controllo alla frequenza di 1 Hz, il suono fa quindi un ‘viaggio’ dal 
canale sinistro al destro e ritorno nel tempo di un secondo: collegando un num- 
ber box a [osc-] possiamo variare la frequenza di oscillazione. 

Provate con frequenze diverse, ma non superiori a 20 Hz: le frequenze superiori 
generano fenomeni di modulazione che tratteremo successivamente. 


Possiamo semplificare la patch usando l'oggetto [vs.pan-], della libreria 
Virtual Sound, che realizza l'algoritmo di panning prendendo un suono dall'in- 
gresso sinistro e spostandolo nel fronte stereo secondo il segnale di controllo 
ricevuto dall'ingresso destro (fig. 4.3). 


fig. 4.3: panning stereofonico con l'oggetto [vs .pan-] 


Come si vede, l'oggetto [vs.pan-] funziona come l'algoritmo di figura 4.2, ma 
permette di liberare spazio nella nostra patch. In questa patch abbiamo anche sosti- 
tuito i due [vs.gain-] con [vs.sgain-], che ne incorpora il funzionamento. 


Possiamo usare come segnale di controllo un'altra forma d'onda, ad esempio 
quella quadra (fig. 4.4). 


vs.kscale- -1 1 0 1 


fig. 4.4: controllo del panning con LFO a forma d'onda quadra 
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In questo caso il suono si sposta da un canale all'altro senza passare per posizio- 
ni intermedie: questa discontinuità genera un clic indesiderato che può essere 
eliminato filtrando il segnale di controllo con un filtro passa-basso ([l1op-]) che 
serve a 'smussare' gli spigoli dell'onda quadra (fig. 4.5). 


fig. 4.5: filtraggio di un LFO 


Qui abbiamo impostato una frequenza di taglio di 20 Hz: questo significa, gros- 
so modo, che il segnale di controllo non può ‘saltare’ da un valore all'altro in un 
tempo inferiore a 1/20 di secondo. Provate a variare la frequenza di taglio del 
filtro per sentirne l'influenza sul percorso del suono: più la frequenza di taglio è 
bassa e più graduale è il passaggio da un canale all'altro. 


(...) 
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II capitolo prosegue con: 

4.3 SEGNALI DI CONTROLLO PER LA FREQUENZA 
II vibrato 
Depth del vibrato 
Rate del vibrato 


4.4 SEGNALI DI CONTROLLO PER L'AMPIEZZA 
Simuliamo un Theremin 


4.5 MODULAZIONE DEL DUTY CYCLE (PULSE WIDTH MODULATION) 
4.6 SEGNALI DI CONTROLLO PER I FILTRI 

4.7 ALTRI GENERATORI DI SEGNALI DI CONTROLLO 

4.8 SEGNALI DI CONTROLLO: IL PANNING MULTICANALE 


ATTIVITÀ 
e Analisi di algoritmi, completamento di algoritmi, correzione di algoritmi, 


VERIFICHE 
e Compiti unitari di reverse engineering, Realizzazione di uno studio breve 


SUSSIDI DIDATTICI 
e Lista oggetti nativi Pd - Lista oggetti della libreria Virtual Sound - Glossario 
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